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本 书 主 审 : 嘉 开 榜 


《计算 机 组 成 原理 ) 一 书 最 初 写作 于 2003 年 ,先后 出 版 了 第 1 一 3 版 ,累计 发 行 20 万 册 。 
本 书 的 第 3 版 出 版 于 2013 年 5 月 , 它 与 配套 的 参考 书 ( 计 算 机 组 成 原理 学 习 指导 与 习题 解 
析 了 (第 3 版) 和 《计算 机 组 成 原理 教师 用 书 》( 第 3 版 ) 均 受到 了 读者 的 欢迎 和 好 评 , 印 刷 13 
次 。 由 于 第 3 版 出 版 迄今 已 6 年 有 余 , 应 广大 同行 和 读者 的 强烈 要 求 ,从 2018 年 9 月 底 开 
始 了 本 次 修订 。 

本 次 修订 未 对 全 书 的 框架 结构 进行 调整 ,只 是 对 部 分 内 容 进 行 了 必要 的 调整 更 新 、 删 
减 , 并 且 参 考 国 内 外 相关 资料 增加 了 一 些 最 新 的 概念 和 技术 。 

修订 后 的 本 书 保持 了 原 书 概念 清楚 通俗 易 懂 的 风格 ,在 强调 基本 原理 .基本 概念 的 同 
时 ,也 注意 了 实用 性 和 先进 性 。 

本 书 每 章 后 附 有 大 量 的 习题 ,在 与 本 书 完 全 配套 的 《计算 机 组 成 原理 教师 用 书 》( 第 4 
版 ) 第 一 曹 的 “教材 习题 解答 ?版块 中 给 出 了 本 书 中 全 部 习题 的 解答 ,以 供 读者 参考 。 

本 人 所 公布 的 电子 邮箱 (bs. jiang@163. com) 多 年 来 收 到 很 多 同行 和 读者 的 来 信 , 均 已 
逐一 认真 回复 。 对 于 一 些 好 的 建议 ,在 本 次 修订 中 也 有 所 体现 。 和 希望 修订 之 后 的 本 书 能 对 
读者 更 有 帮助 ,欢迎 继续 来 信 提 出 宝 贯 意见 和 建议 。 


作 者 
2019 年 3 月 


《计算 机 组 成 原理 ) 一 书 是 本 人 积 多 年 教学 经 验 和 体会 精心 写作 完成 的 ,本 书 第 1 版 出 
版 至 今 已 近 10 年 。 承 索 专 家 和 读者 的 厚爱 ,收获 了 不 少 成 果 。 例 如 《计算机 组 成 原理 》 
2004 年 被 评 为 北京 市 精品 教材 ,2007 年 入 选 教育 部 普通 高 等 教育 “十 一 五 ”国家 级 规划 教 
材 ;《 计 算 机 组 成 原理 (第 2 版 )2009 年 获得 兵 工 高 校 优秀 教 材 一 等 奖 ,《 计 算 机 组 成 原理 》 
(第 2 版 ) 以 及 配套 参考 书 ( 计 算 机 组 成 原理 学 习 指 导 与 习题 解析 》( 第 2 版 )《 计 算 机 组 成 原 
理 教师 用 书 》( 第 2 版 ) 共 3 本 书 在 2011 年 被 评 为 北京 市 精品 教材 《计算 机 组 成 原理 》( 第 2 
版 )2012 年 和 人选 教 育 部 "十 二 五 ?普通 高 等 教育 本 科 国 家 级 规划 教材 。 

本 次 修订 有 比较 大 的 调整 。 首 先是 增加 了 总 线 一 章 ,使 全 书 的 总 章 数 由 8 章 变 为 9 章 。 
然后 ,对 原 有 的 各 草 也 都 进行 了 必要 的 调整 .更 新 、 删 减 ,补充 了 不 少 新 的 内 容 , 特 别 是 为 适 
应 计算 机 飞速 发 展 的 需要 ,参考 国内 外 相关 资料 ,增加 了 不 少 最 新 的 概念 和 技术 , 仅 补 充 和 
更 新 的 内 容 就 近 4 万 字 。 

修订 后 的 本 书 保持 了 原 书 概念 清楚 通俗 易 懂 的 风格 ,在 强调 基本 原理 基本 概念 的 同 
时 ,也 注意 了 实用 性 和 先进 性 。 

此 次 修订 得 到 欧阳 凌 、 潘 海军 的 大 力 支 持 和 帮助 ,他 们 在 资料 收集 .图 表 制 作 ,书稿 整理 
等 方面 参与 了 工作 ,在 此 表示 感谢 。 

继续 欢迎 读者 来 信 提 出 意见 和 建议 ,电子 邮箱 : bs. jiang@163. com。 对 于 读者 的 来 
信 , 本 人 将 会 逐一 回复 。 


作 者 
2013 年 5 月 


承蒙 读者 的 厚爱 ,本 书 第 1 版 出 版 仅 三 年 ,已 连续 印刷 10 次 ,总 印 数 达 到 41 000 册 。 
本 书 2004 年 被 评 为 北京 市 精品 教材 ,2007 年 人 选 教育 部 普通 高 等 教育 “十 一 五 ”国家 级 规 
划 教 材 。 本 书 作 为 主教 材 ,与 2005 年 以 来 相继 出 版 的 (计算 机 组 成 原理 学 习 指 导 与 习题 解 
析 》 和 《计算 机 组 成 原理 教师 用 书 ) 一 起 形成 了 一 个 比较 完整 的 教材 教学 体系 ,可 以 适应 大 多 
数 高 校 的 计算 机 及 相关 专业 “计算 机 组 成 原理 ”课程 教学 的 需要 ,受到 了 许多 老师 的 欢迎 。 

随 着 计算 机 技术 发 展 的 日 新 月 异 , 对 第 1 版 教材 中 部 分 内 容 的 更 新 也 被 提 上 了 议事 日 
程 。 此 次 修订 ,保留 了 原 书 的 框架 和 风格 ,全书 章节 基本 保持 不 变 , 但 与 原 书 相 比 ,进行 了 必 
要 的 调整 、 删 减 , 补 充 了 一 些 新 的 内 容 , 增 加 了 不 少 新 的 概念 和 新 的 技术 。 

第 1 章 增加 哈佛 结构 的 内 容 , 第 3 章 增 加 指令 系统 的 发 展 的 内 容 , 第 5 章 增 加 DDR2 
SDRAM 和 DDR3 SDRAM 等 内 容 , 第 6 曹 增 加 微 处 理 需 中 的 新 技术 的 内 容 , 第 7 草 增 加 
SATA 人 硬盘、NCQ 技术 和 显卡 等 内 容 , 第 8 曹 增加 PCI-Express 总 线 的 内 容 。 

除了 这 些 大 的 变化 ,其 余 章 节 的 内 容 也 有 一 些 修 改 和 补充 。 

修订 后 的 本 书 力求 概念 清楚 、 通 俗 易 懂 , 并 注意 处 理 好 基本 原理 、 基 本 概念 与 实用 性 、 先 
进 性 之 间 的 关系 。 

本 书 第 1 版 自 面市 以 来 , 收 到 了 许多 同行 和 读者 发 来 的 电子 邮件 ,对 于 读者 的 来 信 , 本 
人 均 给 予 了 一 一 回复 和 解答。 希望 修订 之 后 的 本 书 能 对 读者 有 所 帮助 ,欢迎 来 信 提 出 意见 
和 建议 。 电 子 邮 箱 : bs. jiang(@@163. com。 


作 者 
2008 年 6 月 


“计算 机 组 成 原理 ”是 计算 机 类 各 专业 学 生 的 必修 核心 课程 之 一 ,主要 讨论 计算 机 各 大 
部 件 的 基本 组 成 原理 ,各 大 部 件 互 连 构 成 整 机 系统 的 技术 。 本 课程 在 计算 机 学 科 中 处 于 承 
上 启 下 的 地 位 , 先 修 课 程 应 包括 计算 机 基础 .数字 电路 等 。 本 课程 的 参考 教学 时 数 为 56 一 
72 学 时 。 

全 书 共 分 8 章 : 第 1、2 章 介 绍 计算 机 的 基础 知识 (概论 ,数据 的 机 器 层次 表示 )， 
第 3 一 8 章 介 绍 计算 机 的 各 子 系统 (指令 系统 数值 的 机 需 运 算 、 存 储 系 统 和 结构 .中 央 处 理 
器 外 部 设备 、 输 入 输出 系统 ) 的 基本 组 成 原理 。 

本 书 的 内 容 与 教学 时 数 允 许 的 分 量 相 比 俩 多 一 些 , 有 些 内 容 对 某 些 专业 来 说 可 能 已 在 
先导 课程 中 讨论 过 ,因此 ,在 使 用 本 教材 时 ,可 根据 各 专业 的 具体 情况 在 章节 上 有 选择 地 进 
行 取舍 。 

计算 机 组 成 原理 类 的 教材 在 国内 已 有 不 少 , 本 书 在 下 列 几 个 方面 具有 一 定 的 特色 。 

第 一 ,本 书 是 中 国 计 算 机 学 会 和 清华 大 学 出 版 社 共同 规划 的 面向 全 国 高 等 学 校 计算 机 
专业 本 科 生 的 “21 世纪 大 学 本 科 计 算 机 专业 系列 教材 ”之 一 ,内 容 覆 盖 了 《中 国 计 算 机 科学 
与 技术 学 科教 程 2002(CCC2002)》 对 本 课程 所 列 出 的 知识 单元 。 

第 二 ,本 书 既 强调 计算 机 的 基本 概念 和 基础 知识 ,对 计算 机 的 各 大 基本 部 件 的 组 成 原 
理 \ 设 计 方 法 及 相互 关系 都 进行 了 较 详 细 的 描述 ,又 注意 与 实际 应 用 相 结 合 , 具 有 一 定 的 针 
对 性 ,以 避免 理论 和 实际 脱节 。 

第 三 ,计算 机 技术 的 发 展 日 新 月 异 ,作为 一 本 专业 基础 课 教材 ,不 可 能 也 没有 必要 处 处 
体现 先进 技术 ;有 时 过 于 求 新 ,反倒 会 使 内 容 显得 高 深 且 难以 理解 。 本 书 在 阐述 中 注意 巾 浅 
入 深 、 循 序 渐进 ,在 讲 清 基本 原理 的 基础 上 ,再 提出 先进 技术 和 新 的 发 展 方向 ,以 降低 学 习 的 
难度 。 

第 四 ,本 书 根 据 各 章节 内 容 的 要 求 按 横向 方式 组 织 课程 实例 ,而 不 拘泥 于 某 一 种 具体 的 
机 型 ,以 减少 局 限 性 ,扩大 读者 的 视野 和 适用 面 。 考 虑 到 目前 国内 的 实际 情况 ,实例 以 微 .小 
型 计算 机 为 主 。 

第 五 ,为 了 帮助 读者 建立 整 机 概念 ,本 书 中 介绍 了 一 个 仅 有 十 几 条 指令 的 模型 机 ,试图 
通过 解剖 这 样 一 个 小 小 的 “ 麻 和 省 ”来 介绍 控制 器 的 设计 方法 。 

第 六 ,各 章 内 容 相 对 独立 ,由 浅 入 深 ,同时 注意 章节 间 内 容 的 衔接 ,适合 自学 。 

总 之 ,本 书 力求 做 到 内 容 全 面 .概念 清楚 通俗 易 懂 ,并 注意 到 实用 性 和 先进 性 。 

本 书 每 章 后 附 有 大 量 的 习题 ,为 读者 提供 较 多 的 练习 机 会 。 


“计算 机 组 成 原理 ”是 计算 机 类 各 专业 学 生 的 必修 核心 课程 之 一 ,主要 讨论 计算 机 各 大 
部 件 的 基本 组 成 原理 ,各 大 部 件 互 连 构 成 整 机 系统 的 技术 。 本 课程 在 计算 机 学 科 中 处 于 承 
上 启 下 的 地 位 , 先 修 课 程 应 包括 计算 机 基础 .数字 电路 等 。 本 课程 的 参考 教学 时 数 为 56 一 
72 学 时 。 

全 书 共 分 8 章 : 第 1、2 章 介 绍 计算 机 的 基础 知识 (概论 ,数据 的 机 器 层次 表示 )， 
第 3 一 8 章 介 绍 计算 机 的 各 子 系统 (指令 系统 数值 的 机 需 运 算 、 存 储 系 统 和 结构 .中 央 处 理 
器 外 部 设备 、 输 入 输出 系统 ) 的 基本 组 成 原理 。 

本 书 的 内 容 与 教学 时 数 允 许 的 分 量 相 比 俩 多 一 些 , 有 些 内 容 对 某 些 专业 来 说 可 能 已 在 
先导 课程 中 讨论 过 ,因此 ,在 使 用 本 教材 时 ,可 根据 各 专业 的 具体 情况 在 章节 上 有 选择 地 进 
行 取舍 。 

计算 机 组 成 原理 类 的 教材 在 国内 已 有 不 少 , 本 书 在 下 列 几 个 方面 具有 一 定 的 特色 。 

第 一 ,本 书 是 中 国 计 算 机 学 会 和 清华 大 学 出 版 社 共同 规划 的 面向 全 国 高 等 学 校 计算 机 
专业 本 科 生 的 “21 世纪 大 学 本 科 计 算 机 专业 系列 教材 ”之 一 ,内 容 覆 盖 了 《中 国 计 算 机 科学 
与 技术 学 科教 程 2002(CCC2002)》 对 本 课程 所 列 出 的 知识 单元 。 

第 二 ,本 书 既 强调 计算 机 的 基本 概念 和 基础 知识 ,对 计算 机 的 各 大 基本 部 件 的 组 成 原 
理 \ 设 计 方 法 及 相互 关系 都 进行 了 较 详 细 的 描述 ,又 注意 与 实际 应 用 相 结 合 , 具 有 一 定 的 针 
对 性 ,以 避免 理论 和 实际 脱节 。 

第 三 ,计算 机 技术 的 发 展 日 新 月 异 ,作为 一 本 专业 基础 课 教材 ,不 可 能 也 没有 必要 处 处 
体现 先进 技术 ;有 时 过 于 求 新 ,反倒 会 使 内 容 显得 高 深 且 难以 理解 。 本 书 在 阐述 中 注意 巾 浅 
入 深 、 循 序 渐进 ,在 讲 清 基本 原理 的 基础 上 ,再 提出 先进 技术 和 新 的 发 展 方向 ,以 降低 学 习 的 
难度 。 

第 四 ,本 书 根 据 各 章节 内 容 的 要 求 按 横向 方式 组 织 课程 实例 ,而 不 拘泥 于 某 一 种 具体 的 
机 型 ,以 减少 局 限 性 ,扩大 读者 的 视野 和 适用 面 。 考 虑 到 目前 国内 的 实际 情况 ,实例 以 微 .小 
型 计算 机 为 主 。 

第 五 ,为 了 帮助 读者 建立 整 机 概念 ,本 书 中 介绍 了 一 个 仅 有 十 几 条 指令 的 模型 机 ,试图 
通过 解剖 这 样 一 个 小 小 的 “ 麻 和 省 ”来 介绍 控制 器 的 设计 方法 。 

第 六 ,各 章 内 容 相 对 独立 ,由 浅 入 深 ,同时 注意 章节 间 内 容 的 衔接 ,适合 自学 。 

总 之 ,本 书 力求 做 到 内 容 全 面 .概念 清楚 通俗 易 懂 ,并 注意 到 实用 性 和 先进 性 。 

本 书 每 章 后 附 有 大 量 的 习题 ,为 读者 提供 较 多 的 练习 机 会 。 
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第 章 
一 概论 


本 章 从 存储 程序 的 概念 开始 ,讨论 计算 机 的 基本 组 成 与 工作 原理 ,使 读者 对 于 计算 机 系 
统 先 有 一 个 简单 的 整体 概念 ,为 今后 深入 学 习 各 个 部 件 打 下 基础 。 


1.1 电子 计算 机 与 存储 程序 控制 


电子 计算 机 是 一 种 不 需要 人 工 直 接 干 预 ,能 够 月 动 高速、 准确 地 对 各 种 信息 进行 处 理 
和 存储 的 电子 设备 。 电 子 计算 机 从 总 体 上 来 说 可 以 分 为 两 大 类 : 电子 模拟 计算 机 和 电子 数 
字 计 算 机 。 电 子 模拟 计算 机 中 处 理 的 信息 是 连续 变化 的 物理 量 ,运算 的 过 程 也 是 连续 的 ;而 
电子 数字 计算 机 中 处 理 的 信息 是 在 时 间 上 离散 的 数字 量 ,运算 的 过 程 是 不 连续 的 。 通 第 所 
说 的 计算 机 都 是 指 电子 数字 计算 机 。 


1.1.1 电子 计算 机 的 发 展 
1. 计算 机 的 发 展 历史 


人 们 习惯 把 电子 计算 机 的 发 展 历史 分 “ 代 ”, 其实 分 代 并 没有 统一 的 标准 。 最 常见 的 分 
代 方 法 是 根据 计算 机 所 采用 的 电子 名 件 来 划分 的 : 

第 一 代 ,1946 一 1958 年 ,电子 管 计算 机 ，; 

第 二 代 ,1958 一 1964 年 ,晶体管 计 算 机 ; 

第 三 代 ,1964 一 1971 年 ,小 .中 规模 集成 电路 (SSI.MSI) 计算机 

第 四 代 ,1971 一 至 今 ,大 、 超 大 规模 集成 电路 (LSI、VLSD 计 算 机 。 

(1) 电子 管 计 算 机 时 代 

这 一 时 期 的 计算 机 采用 电子 管 作为 基本 器 件 , 初 期 使 用 延迟 线 作为 存储 器 ,以 后 发 明了 
磁 忆 存储 硕 。 早 期 的 计算 机 主要 用 于 科学 计算 ,为 军事 与 国防 尖端 科技 服务 。 

(2) 晶体 管 计算 机 时 代 

这 一 时 期 计算 机 的 基本 器 件 由 电子 管 改 为 晶体 管 ,存储 器 采用 磁 心 存储 器 。 运 算 速 度 
从 每 秒 几 千 次 提高 到 几 十 万 次 ,存储 需 的 容量 从 几 千 存储 单元 提高 到 10 万 存储 单元 以 上 。 
这 不 仅 使 计算 机 在 军事 与 尖端 技术 上 的 应 用 范围 进一步 扩大 ,而 且 在 气象 .工程 设计 、 数 据 
处 理 以 及 其 他 科学 研究 领域 也 得 到 应 用 。 
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(3) 小 .中 规模 集成 电路 计算 机 时 代 

这 一 时 期 的 计算 机 采用 小 .中 规模 集成 电路 为 基本 豆 件 ,因此 功 耗 、 体 积 和 价格 等 进 一 
步 下 降 ,而 速度 及 可 徘 性 相应 提高 ,使 得 计算 机 的 应 用 范围 进一步 扩大 。 

(4) 大 、 超 大 规模 集成 电路 计算 机 时 代 

20 世纪 60 年 代 后 , 微 电 子 技术 发 展 迅 猛 ,半导体 存储 带 问 世 , 迅 速 取 代 了 磁 心 存储 带 ， 
并 不 断 问 大 容量 、 高 集成 度 、 高 速度 方向 发 展 。 从 1971 年 开始 出 现 了 包含 CPU 的 单 片 集成 
电路 ( 微 处 理 带 ), 以 微 处 理 带 为 核心 的 电子 计算 机 就 是 微型 计算 机 。 和 铀 型 计算 机 的 出 现 , 形 
成 了 计算 机 发 展 史上 的 又 一 次 革命 ,使 计算 机 进入 了 几乎 所 有 的 行业 。 

严格 意义 上 说 ,现代 计算 机 还 属于 第 四 代 计 算 机 ,但 是 随 着 集成 电路 的 不 断 发 展 , 单 厂 
集成 电路 的 规模 越 来 越 大 。 有 专家 将 单 片 超过 100 万 品 体 管 以 上 的 集成 电路 称 为 特大 规模 
集成 电路 (ULSD , 单 片 达到 一 亿 到 十 亿 品 体 管 的 集成 电路 称 为 极 大 规模 集成 电路 (ELSD。 


2. 计算 机 的 发 展 趋势 


现在 ,世界 已 进入 了 计算 机 时 代 , 计 算 机 的 发 展 趋势 正 癌 看 “两 极 * 分 化 。 一 极 是 微型 计 
算 机 向 更 微型 化 ,网 络 化 .高 性 能 、 多 用 途 方 回 发 展 。 微 型 计算 机 分 为 台式 机 、 便 携 机 、 笔 记 
本 机 、 亚 笔记 本 机 、 营 上 机 等 。 由 于 它们 体积 小 、 成 本 低 而 占领 了 整个 国民 经 济 和 社会 生活 
的 各 个 领域 。 另 一 极 则 是 巨型 机 癌 更 巨型 化 . 超 高 速 . 并 行 处 理 . 智 能 化 方 回 发 展 。 它 是 一 
个 国家 科技 水 平 、 经 济 实力 .军事 实力 的 象征 。 在 解决 天 气 预报 ` 地 震 分 析 ` 航 空气 动 .流体 
力学 .卫星 遥感 .激光 武 瑚 ,海洋 工程 等 方面 的 问题 上 ,巨型 机 将 大 显 身 手 。 

随 看 新 的 元 融 件 及 其 技术 的 发 展 ,新 型 的 超 导 计 算 机 、 量 子 计算 机 、 光 子 计 算 机 、 生 物 计 
算 机 、 纳 米 计 算 机 等 将 会 在 不 久 的 将 来 走 进 人 们 的 生活 ,遍布 各 个 领域 。 


1.1.2 存储 程序 概念 


世界 上 第 一 台电 子 数字 计算 机 是 1946 年 2 月 在 美国 宾夕法尼亚 大 学 诞生 的 ENIAC 
(Electronic Numerical Integrator and Computer)。ENIAC 是 一 个 庞然大物 , 它 共 用 了 
18 000 多 个 电子 管 , 重 达 30t, 占 地 面积 170m ,每 秒 钟 可 完成 5000 次 加 法 运算 。ENIAC 有 
一 个 很 大 的 缺点 , 即 它 的 存储 容量 极 小 ,只 能 存储 20 个 字 长 为 10 位 的 十 进 制 数 , 所 以 只 能 
用 线路 连接 的 方法 来 编排 程序 ,每 次 解 题 都 要 依 乔 人 工 来 改变 接线 ,准备 时 间 将 大 大 超过 实 
际 计 算 时 间 。 

在 研制 ENIAC 的 同时 ,以 美 籍 匈 牙 利 裔 数学 家 冯 “ 详 依 曼 (John von Neumann) 为 首 
的 研制 小 组 提出 了 “存储 程序 控制 ”的 计算 机 结构 ,并 开始 了 存储 程序 控制 的 计算 机 
EDVAC(Electronic Discrete Variable Automatic Computer) 的 研制。 由 于 种 种 原因 ， 
EDVAC 直到 1951 年 才 问 世 。 而 吸收 了 汉 。 诺 依 曼 的 设计 思想 ,由 英国 剑桥 大 学 人 研制 的 
EDSAC(Electronic Delay Storage Automatic Computer) 则 先 于 它 两 年 诞生 ,成 为 事实 上 的 
第 一 台 存 储 程序 的 计算 机 。 

存储 程序 概念 是 冯 “， 话 依 曼 等 人 于 1945 年 6 月 首先 提出 来 的 , 它 可 以 简要 地 概括 为 以 
下 3 点 : 

J 计算 机 ( 指 硬件 ) 应 由 运算 需 、 存 储 希 、 控 制 硕 、 输 入 设备 和 输出 设备 五 大 基本 部 件 
组 成 。 


G 计算 机 内 部 采用 二 进 制 来 表示 指令 和 数据 。 

G@) 将 编 好 的 程序 和 原始 数据 事先 仓 人 存储 天 中 ,然后 再 局 动 计算 机 工作 ,这 就 是 存储 
程序 的 基本 含义 。 

汉 。 诺 依 曼 对 计算 机 界 的 最 大 页 献 在 于 “存储 程序 控制 ”概念 的 提出 和 实现 。70 多 年 
来 ,虽然 计算 机 的 发 展 速 度 是 惊人 的 ,但 就 其 结构 原理 来 说 ,目前 绝 大 多 数 计算 机 仍 建立 在 
存储 程序 概念 的 基础 上 。 通 常 把 符合 “存储 程序 概念 ”的 计算 机 统称 为 双 。 庄 依 曼 型 计算 
机 。 当 然 ,现代 计算 机 与 早期 计算 机 相 比 在 结构 上 还 是 有 许多 改进 的 。 

随 着 计算 机 技术 的 不 断 发 展 , 也 骑 露出 了 冯 “， 库 依 曼 型 计算 机 的 主要 罚 点 : 存储 天 
访问 会 成 为 瓶颈 。 目 前 已 出 现 了 一 些 突破 存储 程序 控制 的 计算 机 ,统称 为 非 冯 计算 机 ， 
如 数据 驱动 的 数据 流 计 算 机 、 需 求 驱动 的 归 约 计算 机 和 模式 匹配 驱动 的 智能 计算 机 等 。 
本 书 讨论 的 范围 仅 限 于 冯 “， 详 依 曼 型 计算 机 的 组 成 ,有 关 非 汉 计 算 机 将 在 后 续 的 评 程 中 
进行 讨论 。 


1.2 计算 机 的 硬件 组 成 


原始 的 色 。 庄 依 曼 计算 机 在 结构 上 是 以 运算 副 为 中 心 的 ,而 发 展 到 现在 ,已 转向 以 存储 
大 为 中 心 ,图 1-1 为 计算 机 最 基本 的 组 成 框图 。 


1-1 计算 机 的 组 成 


通 稼 将 运算 般 和 控制 天 合 称 为 中 央 处 理 需 (Central Processing Unit,CPU) 。 在 由 超大 
规模 集成 电路 构成 的 微型 计算 机 中 ,往往 将 CPU 制 成 一 块 必 卢 , 称 为 微 处 理 融 。 

中 央 处 理 需 和 主 存储 融 ( 内 存储 希 ) 一 起 组 成 主机 部 分 。 除 去 主机 以 外 的 硬件 装置 (如 
输入 设备 、 输 出 设备 和 辅助 存储 天 等 ) 称 为 外 围 设备 或 外 部 设备 。 


1.2.1 计算 机 的 主要 部 件 
1. 输入 设备 


输入 设备 的 任务 是 把 人 们 编 好 的 程序 和 原始 数据 送 到 计算 机 中 ,并 且 将 它们 转换 成 计 
算 机 内 部 所 能 识别 和 接受 的 信息 方式 。 
按 输入 信息 的 形态 输入 可 分 为 字符 (包括 汉字 ) 输 入 、 图 形 输入 、 图 像 输入 及 语音 输入 
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等 。 目 前 ,常见 的 输入 设备 有 和 键盘、 鼠标 、 扫 描 仪 、 摄 像 涉 、 手 写 输 入 板 等 。 辅助 存 储 冀 ( 磁 
盘 、 磁 带 ) 也 可 以 视 为 输入 设备 。 


2. 输出 设备 


输出 设备 的 任务 是 将 计算 机 的 处 理 结果 以 数字 、 字 符 ( 汉 字 )、 图 形 、 图 像 、 声 音 等 形式 送 
出 计算 机 。 
第 用 的 输出 设备 有 打印 机 、 显 示 带 、 绘 图 仪 等 。 辅 助 存储 天 也 可 以 视 为 输出 设备 。 


3. 存储 器 


存储 器 是 用 来 存放 程序 和 数据 的 部 件 , 它 是 一 个 记忆 装置 ,是 计算 机 能 够 实现 “存储 程 
序 控制 "的 基础 。 

在 计算 机 系统 中 ,规模 较 大 的 存储 器 往往 分 成 若干 级 , 称 为 存储 系统 。 图 1-2 所 示 的 
是 和 常见 的 三 级 存储 系统 。 主 存储 颖 可 由 CPU 直接 访问 , 存 取 速度 
快 ,但 容量 较 小 ,一 般 用 来 存放 当前 正在 执行 的 程序 和 数据 。 辅 
助 存储 器 设置 在 主机 外 部 , 它 的 存储 容量 大 ,价格 较 低 ,但 存 取 束 
度 较 慢 ,一 般 用 来 存放 暂时 不 参与 运行 的 程序 和 数据 。CPU 不 可 
以 直接 访问 辅 存 , 辅 存 中 的 程序 和 数据 在 需要 时 才 传 送 到 主 存 ， 
因此 它 是 主 存 的 补充 和 后 援 。 当 CPU 速度 很 高 时 ,为 了 使 访问 存 
储 融 的 速度 能 与 CPU 的 速度 相 匹 配 , 又 在 主 存 和 CPU 间 增 设 了 图 1-2 三 级 存储 系统 
一 级 Cache( 高 速 缓冲 存储 器 )。Cache 的 存 取 速度 比 主 存 更 快 ,但 
容量 更 小 ,用 来 存放 当前 最 急需 处 理 的 程序 和 数据 ,以 便 快速 地 向 CPU 提供 指令 和 
数据 。 


4. 运算 器 

运算 需 是 对 信息 进行 处 理 和 运算 的 部 件 。 经 稼 进行 的 运算 是 算术 运算 和 逻辑 运算 ,所 
以 运算 需 又 称 为 算术 逻辑 运 侦 部 件 (Arithmetic and Logical Unit,ALU) 。 

运算 融 的 核心 是 加 法 部。 运算 需 中 还 有 奋 干 个 通用 寄存 需 或 累加 寄存 需 , 用 来 暂 存 操 
作 数 并 存放 运算 结果 。 寄 存 副 的 存 取 速度 比 存 储 副 的 存 取 速度 快 得 多 。 

5. 控制 颖 


控制 硕 是 整个 计算 机 的 指挥 中 心 , 它 的 主要 功能 是 按照 人 们 预先 确定 的 操作 步骤 ,控制 
整个 计算 机 的 各 部 件 有 条 不 闪 地 日 动工 作 。 

控制 部 从 主 存 中 逐条 地 取出 指令 进行 分 析 ,根据 指令 的 不 同 来 安排 操作 顺序 , 回 各 部 件 
发 出 相应 的 操作 信号 ,控制 它们 执行 指令 所 规定 的 任务 。 

控制 希 中 包括 一 些 专用 的 寄存 规 。 


1.2.2 计算 机 各 大 部 件 之 间 连 接 
将 前 述 的 各 大 基本 部 件 , 按 某 种 方式 连接 起 来 就 构成 了 计算 机 的 硬件 系统 。 


1. 总 线 结 构 ( 小 、 微 型 机 的 典型 结构 ) 


所 谓 总 线 (Bus) 是 一 组 能 为 多 个 部 件 服务 的 公共 信息 传送 线路 , 它 能 分 时 地 发 送 与 接 
收 各 部 件 的 信息 。 计 算 机 中 采用 总 线 结构 ,可 以 大 大 减少 信息 传送 线 的 数量 ,又 可 以 提高 计 
算 机 扩充 主 存 及 外 部 设备 的 灵活 性 。 

最 简单 的 总 线 结构 是 单 总 线 结构 ,如 图 1-3 所 示 。 各 大 部 件 都 连接 在 单一 的 一 组 总 线 
上 , 故 将 这 个 单 总 线 称 为 系统 总 线 。CPU 与 主 存 .CPU 与 外 设 之 间 可 以 直接 进行 信息 交 
换 , 主 存 与 外 设 、 外 设 与 外 设 之 间 也 可 以 直接 进行 信息 交换 ,而 无 须 经 过 CPU 的 干预 。 


图 1-3 单 总 线 结构 


单 总 线 结构 提高 了 CPU 的 工作 效率 ,而 且 外 设 连接 灵活 ,易于 扩充 。 但 由 于 所 有 部 件 
都 挂 在 同一 组 总 线 上 ,而 总 线 又 只 能 分 时 地 工作 , 故 同 一 时 刻 只 允许 一 对 设备 (或 部 件 ) 之 间 
传送 信息 。 

所 谓 单 总 线 并 不 是 指 只 有 一 根 信号 线 。 系 统 总 线 按 传送 信息 的 不 同 可 以 细 分 为 地 址 总 
线 .数据 总 线 和 控制 总 线 。 地 址 总 线 (Address Bus) 由 单方 向 的 多 根 信号 线 组 成 ,用 于 CPU 
回 主 存 、 外 设 传输 地 址 信息 ;数据 总 线 (Data Bus) 由 双方 回 的 多 根 信 号 线 组 成 ,CPU 可 以 沿 
这 些 线 从 主 存 或 外 设 读 人 数据 ,也 可 以 沿 这 些 线 向 主 存 或 外 设 送 出 数据 ;控制 总 线 (Control 
Bus) 上 传输 的 是 控制 信息 ,包括 CPU 送出 的 控制 命令 和 主 存 (或 外 设 ) 返 回 CPU 的 反馈 
信号 。 

总 线 结构 是 小 、 微 型 计算 机 的 典型 结构 。 这 是 因为 小 、 微 型 计算 机 的 设计 目标 是 以 较 小 
的 硬件 代价 组 成 具有 较 强 功能 的 系统 ,而 总 线 结构 正好 能 满足 这 一 要 求 。 


2. 大 中 型 计算 机 的 典型 结构 


大 中 型 计算 机 系统 的 设计 目标 更 者 重 于 系统 功能 的 扩大 与 效率 的 提高 。 图 1-4 为 大 、 
中 型 计算 机 的 典型 结构 图 。 在 系统 连接 上 分 为 四 级 : 主机 、 通 道 . 设 备 控制 融和 外 部 设备 。 

通道 是 承担 1/O 操作 管理 的 主要 部 件 , 每 个 通道 可 以 接 一 台 或 几 台 设备 控制 部 ,每 个 
设备 控制 带 又 可 接 一 台 或 几 台 外 部 设备 ,这 样 整个 系统 就 可 以 连接 很 多 的 外 部 设备 。 这 种 
结构 具有 较 大 的 扩充 变化 余地 。 对 较 小 的 系统 来 说 ,可 将 设备 控制 硕 与 外 设 合 并 在 一 起 ,将 
通道 与 CPU 合并 在 一 起 ;对 较 大 的 系统 , 则 单独 设置 通 近 部 件 ; 对 更 大 的 系统 ,通道 可 发 展 
成 为 具有 处 理 功 能 的 外 围 处 理 机 。 


1.2.3 不 同 对 象 观 察 到 的 计算 机 硬件 系统 
从 第 一 台 计算 机 诞生 至 今 ,已 经 经 历 了 70 多 年 的 风 风 雨 雨 ,目前 计算 机 可 以 说 已 经 无 
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1-4 大 、 中 型 计算 机 的 典型 结构 


处 不 在 无 事 不通 。 在 绝 大 多 数 的 人 看 来 ,计算 机 (主要 指 微型 计算 机 ) 已 不 再 是 陌生 和 充满 
玄机 的 神秘 之 物 ,而 仅仅 是 一 种 常用 工具 而 已 。 然 而 不 同 对 象 所 观察 到 的 计算 机 人 硬件 系统 
是 不 相同 的 ,所 涉及 的 技术 问题 也 是 不 同 层 次 的 ,下 面 仅 以 微型 计算 机 为 例 来 分 析 它 们 之 间 
的 区 别 。 


1. 一 般 用 户 观 察 到 的 计算 机 硬件 系统 


一 般 用 户 是 指 那些 仅 局 限于 使 用 计算 机 最 基本 功能 的 用 户 。 他 们 观察 到 的 只 是 计算 机 
的 用 户 界 面 ,如 人 机 交互 使 用 的 键盘 、 鼠 标 、 显 示 兹 ， 
用 于 存储 信息 的 磁盘 、 光 盘 等 ,计算 机 本 身 对 于 他 们 
来 说 只 是 一 个 或 立 或 四 在 那里 的 铁 箱子 ,至 于 它 内 
部 的 结构 和 组 成 .工作 原理 等 都 是 不 必 关 心 的 。 一 
般 用 户 观 察 到 的 计算 机 硬件 系统 如 图 1-5 所 示 。 


2. 专业 用 亡 观 察 到 的 计算 机 硬件 系统 


专业 用 户 观察 到 的 计算 机 硬件 系统 要 比 一 般 用 ”图 1-5 一 般 用 户 观 察 到 的 计算 机 
户 深入 得 多 ,他 们 可 能 更 多 地 关注 计算 机 机 箱 内 各 缆 件 系统 
部 分 的 结构 和 组 成 ,专业 用 户 观察 到 的 计算 机 硬件 系统 如 图 1-6 所 示 。 

1-6 中 除了 键盘 、 显示 需 以 外 ,其 余部 分 都 在 机 箱 内 。 机 箱 中 的 核心 是 主板 , 微 处 理 
器 内存 条 、 外 部 高 速 缓冲 存储 器 (Cache) .显卡 、 磁 盘 控 制 器 等 可 以 直接 制作 在 主板 上 或 插 
在 主板 上 。 近 年 的 计算 机 已 都 将 外 部 Cache 集成 在 微 处 理 器 芯片 中 了 。 


3. 计算 机 设计 者 观察 到 的 计算 机 硬件 系统 


计算 机 的 设计 者 更 多 地 关心 计算 机 的 组 成 原理 和 实现 方法 ,图 1-7 所 示 的 是 计算 机 设 
计 者 观察 到 的 计算 机 硬件 系统 ,此 时 计算 机 的 硬件 系统 被 进一步 分 解 。 

从 图 1-7 可 以 看 出 ,计算 机 人 硬件 系统 是 由 运算 带 、 控 制 副 存储 副 和 外 设 组 成 的 ,这 就 
是 系统 级 。 系 统 级 是 由 寄存 帮 级 组 成 的 ,寄存 大 级 又 是 由 门 级 组 成 的 , 门 级 最 后 由 晶体 
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1-6 专业 用 户 观 察 到 的 计算 机 硬件 系统 
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图 1-7 计算 机 设计 者 观察 到 的 计算 机 硬件 系统 


管 级 组 成 ,而 晶体 管 的 物理 实现 主要 有 两 种 : 金属 氧化 物 半导体 (MOS) 和 品 体 管 - 品 体 管 
逻辑 (TTL) 。 


1.2.4 轨 . 诺 依 时 结构 和 哈佛 结构 的 存储 器 设计 思想 


前 面 已 经 提 到 过 冯 。 诺 依 曼 计算 机 的 存储 程序 概念 ,然而 根据 程序 (指令 序列 ) 和 数据 
的 存放 形式 ,存储 右 设 计 思 想 又 可 以 分 为 汉 。 诺 依 曼 结构 和 哈佛 结构 。 
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1. 冯 ，。 诺 依 曼 结 构 


妈 。 庄 依 曼 结构 也 称 普 林 斯 顿 结构 ,是 一 种 传统 的 存储 副 设 计 思 想 , 即 指令 和 数据 是 不 
加 区 别 地 混合 存储 在 同一 个 存储 天 中 的 ,共享 数据 
总 线 ,如 图 1-8 所 示 。 指 令 地 址 和 数据 地 址 指 癌 同 
一 个 存储 需 的 不 同 物理 位 置 ,指令 和 数据 的 宽度 相 
同 。 由 于 指令 和 数据 存放 在 同一 存储 右 中 ,因此 冯 
“ 许 依 曼 结 构 中 不 能 同时 取 指 令 和 取 操 作 数 。 又 ”图 18 冯 . 诺 依 曼 结 构 的 存储 器 设计 
由 于 存储 器 存 取 速度 远 远 低 于 CPU 运算 速度 ,从 
而 使 计算 机 运算 速度 受到 很 大 限制 ,CPU 与 共享 存储 右 间 的 信息 交换 成 了 影响 高 速 计算 和 
使 用 冯 。 庄 依 曼 结构 的 中 央 处 理 器 是 很 多 的 。 例 如 ,Intel 公司 的 80x86 及 其 他 中 央 处 
理 融 、ARM 公司 的 ARM7 和 MIPS 公司 的 MIPS 等 也 都 采用 了 冯 。 庄 依 曼 结构 。 


2. 哈佛 结构 


冯 。 庄 依 曼 结构 在 面 对 高 速 、 实 时 处 理 时 ,不 可 避免 会 造成 总 线 拥 挤 。 为 此 ,哈佛 大 学 
提出 了 与 汉 。 庄 依 曼 结构 完全 不 同 的 男 一 种 存储 器 设计 思想 ,人 们 习惯 称 之 为 哈佛 结构 。 
哈佛 结构 的 指令 和 数据 是 完全 分 开 的 ,存储 器 分 为 两 部 分 ,一 个 是 程序 存储 器 ,用 来 存放 指 
令 , 另 一 个 是 数据 存储 需 , 用 来 存放 数据 。 哈 佛 结构 至 少 有 两 组 总 线 : 程序 存储 右 (PM) 的 
数据 总 线 和 地 址 总 线 , 数 据 存储 器 CDM) 的 数据 总 线 和 地 址 总 线 , 如 图 1-9 所 示 。 这 种 分 离 
的 程序 总 线 和 数据 总 线 , 可 人 允许 同时 获取 指令 字 ( 来 和 月 程序 存储 需 ) 和 操作 数 ( 来 目 数 据 存 储 
锋 ) 而 互 不 干扰 。 这 意味 着 在 一 个 机 器 周期 内 可 以 同时 准备 好 指令 和 操作 数 , 本 条 指令 执行 
时 可 以 预先 读 取 下 一 条 指令 ,所 以 哈佛 结构 的 中 央 处 理 帮 通常 具有 较 高 的 执行 效率 。 同 时 ， 
由 于 指令 和 数据 分 开 存 放 , 可 以 使 指令 和 数据 有 不 同 的 数据 宽度 ,如 Microchip 公司 的 
PIC16 芯片 的 指令 宽度 为 14 位 ,而 数据 宽度 为 8 位 。 


1-9 哈佛 结构 的 存储 器 设计 


使 用 哈佛 结构 的 中 央 处 理 器 有 很 多 。 例 如 ,Motorola 公司 的 MC68 系列 ,Zilog 公司 的 
Z8 系列 ,以 及 ARM 公司 的 ARM9、ARM10 和 ARM11。 大 多 数 单 片 机 和 数字 信号 处 理 
(DSP) 系 统 部 使 用 哈佛 结构 。 

目前 ,许多 现代 微型 计算 机 中 的 高 速 缓冲 存储 颖 (Cache) 采 用 哈佛 结构 ,将 Cache 分 为 
指令 Cache 和 数据 Cache 两 个 部 分 ,而 主 存储 帮 采 用 冯 。 诺 依 曼 结 构 , 只 有 一 个 ,由 指令 和 
数据 合用 。 如 此 将 汉 ，。 庄 依 曼 结构 和 哈佛 结构 结合 起 来 ,不 仅 可 以 提高 主 存储 器 的 利用 率 ， 
而 且 可 以 提高 程序 执行 的 效率 ,缩短 指令 执行 的 时 钟 周 期 。 


1.3 计算 机 系统 


一 个 完整 的 计算 机 系统 包含 硬件 系统 和 软件 系统 两 大 部 分 。 硬 件 通常 是 指 一 切 看 得 
见 、 摸 得 到 的 设备 实体 ;软件 通常 是 泛 指 各 类 程序 和 文件 ,它们 实际 上 是 由 一 些 算 法 以 及 其 
在 计算 机 中 的 表示 所 构成 的 。 


1.3.1 硬件 与 软件 的 关系 


人 硬件 是 计算 机 系统 的 物质 基础 , 正 是 在 硬件 高 度 发 展 的 基础 上 , 才 有 软件 赖 以 生存 的 空 
间 和 活动 场所 ,没有 硬件 对 软件 的 支持 ,软件 的 功能 就 无 从 谈 起 ;同样 ,软件 是 计算 机 系统 的 
灵魂 ,没有 软件 的 硬件 “ 裸 机 ”将 不 能 提供 给 用 户 使 用 ,犹如 一 堆 废 铁 。 因 此 ,人 硬件 和 软件 是 
相辅相成 、 不 可 分 割 的 整体 。 

当前 ,计算 机 的 硬件 和 软件 正 朝 着 互相 渗透 、 互 相 融 合 的 方向 发 展 , 在 计算 机 系统 中 没 
有 一 条 明确 的 硬件 与 软件 的 分 界线 。 原 来 一 些 由 硬件 实现 的 功能 可 以 改 由 软件 模拟 来 实 
现 , 这 种 做 法 称 为 硬件 软化 , 它 可 以 增强 系统 的 功能 和 适应 性 ;同样 ,原来 由 软件 实现 的 功能 
也 可 以 改 由 硬件 来 实现 , 称 为 软件 硬化 , 它 可 以 显著 降低 软件 在 时 间 上 的 开销 。 由 此 可 见 ， 
硬件 和 软件 之 间 的 界面 是 浮动 的 ,对 于 程序 设计 人 员 来 说 ,硬件 和 软件 在 逻辑 上 是 等 价 的 。 
一 项 功能 究竟 采用 何 种 方式 实现 ,应 该 从 系统 的 效率 .速度 .价格 和 资源 状况 等 诸多 方面 综 
合 考 虑 。 

既然 硬件 和 软件 不 存在 一 条 固定 的 一 成 不 变 的 界线 ,那么 今天 的 软件 可 能 就 是 明天 的 
硬件 ,今天 的 硬件 也 可 能 就 是 明天 的 软件 。 

除去 硬件 和 软件 ,还 有 一 个 概念 需要 引起 注意 ,这 就 是 固件 (Firmware)。 固 件 一 词 是 
1967 年 由 美国 人 A。， Opler 首先 提出 来 的 。 固件 是 指 那 些 存 储 在 能 永久 保存 信息 的 器 件 
(如 ROM) 中 的 程序 ,是 具有 软件 功能 的 硬件 。 固 件 的 性 能 指标 介 于 硬件 与 软件 之 间 , 吸 收 
了 软 、 硬 件 各 自 的 优点 ,其 执行 速度 快 于 软件 ,灵活 性 优 于 硬件 ,是 软 、 硬 件 结合 的 产物 ,计算 
机 功能 的 固件 化 将 成 为 计算 机 发 展 的 一 个 趋势 。 


1.3.2 系列 机 和 软件 兼容 


计算 机 技术 是 飞速 发 展 的 技术 , 随 着 元 器 件 、 便 件 技术 和 工业 生产 能 力 的 迅猛 发 展 ， 
新 的 高 性 能 的 计算 机 不 断 地 被 研制 和 生产 出 来 。 用 户 希 望 在 新 的 计算 机 系统 出 台 后 , 原 
先 已 开发 的 软件 仍 能 继续 在 升级 换代 后 的 新 型 号 的 机 器 上 使 用 ,这 就 要 求 软件 具有 可 兼 
容 性 。 

所 谓 系 列 机 ,是 指 一 个 广 家 生产 的 ,具有 相同 的 系统 结构 ,但 具有 不 同 组 成 和 实现 的 一 
系列 不 同型 号 的 机 大 。 

系列 机 从 程序 设计 者 的 角度 看 具有 相同 的 机 需 属 性 , 即 相 同 的 系统 结构 。 这 里 的 相同 
是 指 在 指令 系统 ,数据 格式 .字符 编码 .中 断 系 统 .控制 方式 和 输入 输出 操作 方式 等 多 个 方面 
保持 统一 ,从 而 保证 了 软件 的 兼容 。 系 列 机 的 软件 兼容 分 为 加 上 兼容 .加 下 兼容 .加 前 兼容 
和 回 后 兼容 4 种 。 癌 上 (下 ) 兼 容 指 的 是 按 某 档次 机 需 编 制 的 程序 ,不 加 修改 就 能 运行 在 比 
它 更 高 ( 低 ) 档 的 机 需 上 ;加 前 (后 ) 兼 容 是 指 按 某 个 时 期 投入 市 场 的 某 种 型 号 机 融 编制 的 程 
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序 , 不 加 修改 就 能 运行 在 它 之 前 (后 ) 投 入 市 场 的 机 器 上 。 首 中 
图 1-10 形 象 地 说 明了 兼容 性 的 概念 。 对 系列 机 的 软件 向 
下 和 向 前 兼容 可 以 不 作 要 求 ,但 必须 保证 向 后 兼容 ,力争 
做 到 向 上 兼容 。 


1.3.3 计算 机 系统 的 多 层次 结构 
现代 计算 机 系统 是 一 个 硬件 与 软件 组 成 的 综合 


可 以 把 它 看 作 按 功能 划分 的 多 级 层次 结构 ,如 图 1-11 时 间 


所 示 。 图 1-10 兼容 性 示意 
第 雯 级 是 便 联 逻辑 级 ,这 是 计算 机 的 内 核 , 由 门 、 触 
发 大 等 逻辑 电路 组 成 。 


当前 机 器 


nd pds 
| 
| 
| 


向 前 | 向 后 
兼容 1 兼容 


第 六 级 应 用 语言 机 项 M6 
(虚拟 机 顷 ) 具有 L6 机 和 盔 语 言 (应 用 语言 ) 
翻译 (应 用 软件 包 ) 


第 五 级 高 级 语言 机 器 M5 
(虚拟 机 器 ) | ”具有 LS 机 器 语言 (高 级 语言 ) 
翻译 (编译 程序 ) 
第 四 级 汇编 语言 机 器 M4 
(虚拟 机 器 ) | 。 具有 IL4 机 器 语言 (汇编 语言 ) 
翻译 (汇编 程序 ) 
第 三 级 操作 系统 机 器 M3 
(虚拟 机 器 ) | 具有 L3 机 器 语言 (作业 控制 语言 等 ) 
部 分 解释 (操作 系统 ) 
第 二 级 传统 机 器 M2 
(实际 机 器 ) | 具有 L2 机 器 语言 (机 器 指令 语言 ) 
解释 
第 一 级 微 程序 机 器 MI 
(实际 机 器 ) | “具有 LI1 机 器 语言 ( 微 指令 系统 ) 
硬件 直接 执行 


第 零 级 
(实际 机 器 ) 候 联 逐条 
1-11 计算 机 系统 的 多 层次 结构 


第 一 级 是 微 程序 机 带 级 。 这 级 的 机 帮 语 言 是 微 指令 集 , 用 微 指 令 编写 的 微 程序 一 般 是 
直接 由 硬件 执行 的 。 

第 二 级 是 传统 机 需 级 。 这 级 的 机 需 语 言 是 该 机 的 指令 集 , 用 机 需 指 令 编写 的 程序 可 以 
由 微 程序 进行 解释 。 

第 三 级 是 操作 系统 机 紫 级 。 从 操作 系统 的 基本 功能 来 看 ,一 方面 它 要 直接 管理 传统 机 
全 中 的 软 刹 件 资源 ,为 一 方面 它 又 是 传统 机 禹 的 延伸 。 

第 四 级 是 汇编 语言 机 絮 级 。 这 级 的 机 带 请 言 是 汇编 语言 ,完成 汇编 语言 翻 详 的 程序 称 
为 汇编 程序 。 


- 


榜 
第 五 级 是 高 级 语言 机 络 级 。 这 级 的 机 带 语 言 就 是 各 种 遍 级 语言 ,通常 用 编译 程序 来 完 
成 高 级 语言 翻译 的 工作 。 
第 六 级 是 应 用 语言 机 融 级 。 这 一 级 是 为 了 使 计算 机 满足 某 种 用 途 而 专门 设计 的 ,因此 
这 一 级 语言 就 是 各 种 面向 问题 的 应 用 语言 。 
把 计算 机 系统 按 功 能 划分 成 多 级 层次 结构 ,有 利于 正确 理解 计算 机 系统 的 工作 过 程 , 明 
确 软 件 、 便 件 在 计算 机 系统 中 的 地 位 和 作用 。 


1.3.4 实际 机 器 和 虚拟 机 器 


在 图 1-11 所 示 的 多 级 层次 结构 中 ,对 每 一 个 机 器 级 的 用 户 来 说 ,都 可 以 将 此 机 器 级 看 
作 一 台独 立 的 使 用 自己 特有 的 “机 器 语言 "的 机 响 。 

实际 机 器 是 指 由 硬件 或 固件 实现 的 机 器 ,如 图 1-11 所 示 的 第 零 级 到 第 二 级 。 虚 拟 机 器 
是 指 以 软件 或 以 软件 为 主 实现 的 机 器 ,如 图 1-11 所 示 的 第 三 级 到 第 六 级 。 

虚拟 机 器 只 对 该 级 的 观察 者 存在 , 即 在 某 一 级 观察 者 看 来 ,他 只 需要 通过 该 级 的 语言 
了 解 和 使 用 计算 机 ,至 于 下 级 是 如 何 工 作 和 实现 就 不 必 关 心 了 。 如 高 级 语言 级 机 器 及 应 用 
语言 机 器 级 的 用 户 ,不 必 了 解 机 器 的 具体 组 成 ,不 必 熟 悉 指 令 系 统 , 直 接 用 所 指定 的 语言 描 
述 所 要 解决 的 问题 即 可 。 


1.4 计算 机 的 工作 过 程 和 主要 性 能 指标 


为 使 计算 机 按 预 定 要 求 工 作 ,首先 要 编制 程序 。 程 序 是 一 个 特定 的 指令 序列 , 它 告 诉 计 
算 机 要 做 哪些 事 , 按 什么 步骤 去 做 。 指 令 是 一 组 二 进 制 信息 的 代码 ,用 来 表示 计算 机 所 能 完 
成 的 基本 操作 。 


1.4.1 计算 机 的 工作 过 程 


编制 好 的 程序 放 在 主 存 中 ,由 控制 右 控 制 逐条 取出 指令 执行 ,下 面 以 一 个 例子 来 加 以 
说 明 。 

例如 : 计算 a 十 6 一 c=?( 设 a、b、c 为 已 知 的 3 个 数 ,分 别 存放 在 主 存 的 5 一 7 号 单元 
中 ,结果 将 存放 在 主 存 的 8 号 单元 ) ,如 果 采 用 单 累 加 寄存 硕 结 构 的 运算 需 , 完 成 上 述 计算 至 
少 需要 5 条 指令 ,这 5 条 指令 依次 存放 在 主 存 的 0 一 4 号 单元 中 ,参加 运算 的 数 也 必须 存放 
在 主 存 指定 的 单元 中 , 主 存 中 有 关 单 元 的 内 容 如 图 1-12(a) 所 示 。 运 算 需 的 简单 框图 如 
图 1-12(b) 所 示 ,参加 运算 的 两 个 操作 数 一 个 来 自 累 加 寄存 器 ,一 个 来 自主 存 , 运 算 结 果 则 
放 在 累加 寄存 器 中 。 图 1-12(b) 中 的 存储 硕 数据 寄存 需 是 用 来 暂 存 从 主 存 中 读 出 的 数据 或 
写 人 主 存 的 数据 的 , 它 本 身 不 属于 运算 需 的 范畴 。 

计算 机 的 控制 硕 将 控制 指令 逐条 地 执行 ,最终 得 到 正确 的 结果 ,步骤 如 下 : 

J 执行 取 数 指令 ,从 主 存 5 号 单元 取出 数 ec, 送 入 累加 寄存 关中 。 

@ 执行 加 法 指令 ,将 累加 寄存 器 中 的 内 容 a 与 从 主 存 6 号 单元 取出 的 数 2 一 起 送 到 
ALU 中 相 加 ,结果 a 十 5b 保留 在 累加 寄存 器 中 。 

@ 执行 减法 指令 ,将 累加 寄存 器 中 的 内 容 a 十 5b 与 从 主 存 7 号 单元 取出 的 数 c 一 起 送 到 
ALU 中 相 减 ,结果 a 十 6 一 c 保留 在 累加 寄存 器 中 。 
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1-12 计算 机 执行 过 程 实例 


主 存储 货 


由 执行 存 数 指令 ,把 累加 寄存 天 的 内 容 a 十 5 一 c 存 至 主 存 8 号 单元 。 
(3 执行 停机 指令 ,计算 机 停止 工作 。 


1.4.2 计算 机 的 主要 性 能 指标 


为 了 进一步 了 解 计 算 机 的 特性 ,全 面 衡量 一 台 计 算 机 的 性 能 ,下 面 介 绍 计算 机 的 主要 性 
能 指标 。 


1. 机 咽 字 长 


机 费 字 长 是 指 参 与 运算 的 数 的 基本 位 数 , 它 是 由 加 法 右 、 寄 存 带 的 位 数 决定 的 ,所 以 机 
需 字 长 一 般 等 于 内 部 寄存 大 的 大 小 。 字 长 标志 着 精度 , 字 长 越 长 ,计算 的 精度 就 越 高 。 

在 计算 机 中 为 了 更 灵活 地 表达 和 处 理 信 息 , 以 字 节 (Byte) 为 基本 单位 , 字 节 用 大 与 字母 
B 表示 。 一 个 字 节 等 于 8 位 二 进 制 位 (bit) ,位 用 小 写字 母 b 表示 。 通 党 所 说 的 字 (Word) 是 
指数 据 字 ,不同 的 计算 机 ,数据 字 长 度 可 以 不 相同 ,但 对 于 系列 机 来 说 ,数据 字 的 长 度 应 该 是 
固定 的 。 例 如 ,Intel 80x86 系列 中 ,一 个 数据 字 等 于 16 位 ;IBM 303X 系列 中 ,一 个 数据 字 
等 于 32 位 。 

需要 注意 的 是 ,这 里 所 说 的 字 ( 数 据 字 ) 和 字 长 (机 需 字 长 ) 的 概念 是 有 区 别 的 , 字 实 际 上 
是 一 个 度量 单位 ,用 来 度量 各 种 数据 类 型 的 宽度 ,而 字 长 表示 数据 运算 的 宽度 ,反映 了 计算 
机 处 理 信息 的 能 力 。 它 们 两 者 的 长 度 可 以 一 样 ,也 可 以 不 一 样 。 


2. 数据 通路 宽度 


数据 总 线 一 次 所 能 并 行 传 送信 息 的 位 数 , 称 为 数据 通路 宽度 。 它 影响 到 信息 的 传送 能 
力 , 从 而 影响 计算 机 的 有 效 处 理 速 度 。 这 里 所 说 的 数据 通路 宽度 是 指 外 部 数据 总 线 的 宽度 ， 
它 与 CPU 内 部 的 数据 总 线 宽度 (内 部 寄存 器 的 位 数 ) 有 可 能 不 同 。 有 些 CPU 的 内 、 外 数据 
总 线 宽度 相等 ,如 Intel 8086、80286、80486 等 ;有 些 CPU 的 外 部 数据 总 线 宽度 小 于 内 部 ,如 
8088 .80386SX 等 ;也 有 些 CPU 的 外 部 数据 总 线 宽度 大 于 内 部 ,如 Pentium 等 。 所 有 的 
Pentium 都 有 64 位 外 部 数据 总 线 和 32 位 内 部 寄存 融 一 一 这 一 结构 看 起 来 似乎 有 问题 ,这 


是 因为 Pentium 有 两 条 32 位 流水 线 , 它 就 像 两 个 合 在 一 起 的 32 位 芯片 ,64 位 数据 总 线 可 
以 满足 高 效 地 充满 多 个 寄存 器 的 需要 。 
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一 个 主 存储 器 所 能 存储 的 全 部 信息 量 称 为 主 存 容量 。 通 常 ,以 字 节 数 来 表示 存储 容量 ， 
这 样 的 计算 机 称 为 字 节 编 址 的 计算 机 。 也 有 一 些 计 算 机 是 以 字 为 单位 编 址 的 ,它们 用 字数 
乘 以 字 长 来 表示 存储 容量 。 在 表示 容量 大 小 时 ,经 常用 到 K、M、G、T、\P 之 类 的 字符 ,它们 
与 通常 意义 上 的 K、M、G、T、P 有 些 差异 ,如 表 1-1 所 示 。 


表 1-1 KMGT、P 的 定义 


K (Kilo) 22 一 1024 

M( Mega) 220 一 1 048 576 

G(Giga) 2? 一 1 073 741 824 
T(Tera) 22” 一 1 099 511 627 776 

P( Peta) 2”" 一 1 125 899 906 842 624 


1024 个 字 节 称 为 1KB,1024KB 称 为 1MB,1024MB 称 为 1GB…… 计算 机 的 主 存 容量 
越 大 ,存放 的 信息 就 越 多 ,处 理 问题 的 能 力 就 越 强 。 


4. 运算 速度 
计算 机 的 运算 速度 与 许多 因素 有 关 , 如 机 需 的 主 频 、 执 行 什么 样 的 操作 以 及 主 存 本 身 的 


(1) 硬 吐 量 和 啊 应 时 间 

厨 吐 量 是 指 系统 在 单位 时 间 内 处 理 请 求 的 数量 。 啊 应 时 间 是 指 系统 对 请 求 作出 啊 应 的 
时 间 , 啊 应 时 间 包括 CPU 时 间 ( 运 行 一 个 程序 所 花费 的 时 间 ) 与 等 每 时 间 ( 用 于 磁盘 访问 、 
存储 天 访问 .IO 操作 .操作 系统 开销 等 时 间 ) 的 总 和 。 

(2) 主 频 和 CPU 时 钟 周期 

CPU 的 主 频 又 称 为 时 钟 频率 ,表示 在 CPU 内 数字 脉冲 信号 振荡 的 速度 。 主 频 的 倒数 
就 是 CPU 时 钟 周期 ,这 是 CPU 中 最 小 的 时 间 元 素 。 每 个 动作 至 少 需要 一 个 时 钟 周期 。 

(9) CPI 

CPI(Cycles per Instruction) 是 指 每 条 指令 执行 所 用 的 时 钟 周 期 数 。 在 现代 高 性 能 计 
算 机 中 ,由 于 采用 各 种 并 行 技 术 ,使 指令 执行 高 度 并 行 化 ,和 常 肖 是 一 个 系统 时 钟 周 期 内 可 以 
处 理 敬 干 条 指令 ,所 以 CPI 参数 经 常用 IPC(Instructions per Cycle) 表 示 , 即 每 个 时 钟 周 期 
执行 的 指令 数 。 


IPC= 


(4) CPU 执行 时 间 


和 ri CPU 时 钟 周 期 数 _ 指令 数 XCPI 
CPU 执行 时 间 == 时 钟 频 率 时 钟 频率 
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(5) MIPS 和 MFLOPS 
MIPS(Million Instructions per Second) 表 示 每 秒 执行 多 少 百 万 条 指令 。 对 于 一 个 给 定 
指令 条 数 主 频 _， 
ne X 
A 执行 时 间 X10 CPI 主 频 XIPC 
这 里 所 说 的 指令 一 般 是 指 加 、 减 运算 这 类 短 指令 。 
MFLOPS(Million Floating-point Operations per Second) 表 示 每 秒 执行 多 少 百 万 次 浮 
点 运算 。 对 于 一 个 给 定 的 程序 ,MFLOPS 定义 为 : 
、 _ 浮 点 操作 次 数 
MFLOPS 执行 时 间 X10 


MFLOPS 适用 于 衡量 回 量 机 的 性 能 。 
习 十 


1-1 电子 数字 计算 机 和 电子 模拟 计算 机 的 区 别 在 哪里 ? 

1-2 冯 。 诺 依 曼 计算 机 的 特点 是 什么 ?其 中 最 主要 的 一 点 是 什么 ? 
1-3 计算 机 的 硬件 是 由 哪些 部 件 组 成 的 ? 它们 各 有 哪些 功能 ? 

1-4 什么 叫 总 线 ? 简 述 单 总 线 结构 的 特点 。 

1-5 简 述 计算 机 的 层次 结构 ,说 明 各 层次 的 主要 特点 。 

1-6 计算 机 系统 的 主要 技术 指标 有 哪些 ? 


沿 了 章 
数据 的 机 器 层次 表示 


数据 是 计算 机 加 工 和 处 理 的 对 象 ,数据 的 机 絮 层 次 表示 将 十 接 有 影响 到 计算 机 的 结构 和 
性 能 。 本 草 主 要 介绍 无 符号 数 和 市 符号 数 的 表示 方法 、 数 的 定点 与 浮 扣 表示 方法 、 字 和 从 和 汉 
字 的 编码 方法 .数据 校 验 码 等 。 熟 悉 和 和 掌握 本 章 的 内 容 是 学 习 计 算 机 原理 的 最 基本 要 求 。 


2.1 数值 数据 的 表示 


在 计算 机 中 ,采用 数字 化 方式 来 表示 数据 ,数据 有 无 符号 数 和 市 符号 数 之 分 ,其 中 市 符 
号 数 根据 其 编码 的 不 同 又 有 原 码 、 补 码 和 反 码 3 种 表示 形式 。 


2.1.1 计算 机 中 的 数值 数据 


人 们 在 日 常生 活 中 最 常 使 用 的 是 十 进 制 数 , 这 恕 怕 和 人 有 十 个 手指 涉 是 分 不 开 的 。 然 
而 ,在 计算 机 中 数据 通常 用 二 进 制 数 来 表示 ,任何 数值 数据 都 可 以 由 一 串 “0” 或 “1” 的 数字 构 
成 。 考 虑 到 二 进 制 数位 数 比 较 长 ,书写 起 来 不 方便 ,在 计算 机 中 也 使 用 八进制 和 十 六 进 制 来 
表示 数值 数据 。 

为 了 避免 出 现 误会 ,在 给 出 一 个 数 的 同时 就 必须 指明 这 个 数 的 数 制 。 例 如 ,(1010)，、 
(1010)s 、(1010)1o、(1010)16 所 代表 的 数值 就 不 同 。 除 了 用 下 标 来 表示 不 同 的 数 制 以 外 ,在 
计算 机 中 还 常用 后 级 字母 来 表示 不 同 的 数 制 。 后 级 B 表示 这 个 数 是 二 进 制 数 (Binary) ;后 
级 Q 表示 这 个 数 是 八进制 数 (Octal) ,本 来 八进制 数 的 英文 单词 的 第 一 个 字母 应 当 是 0, 因 
为 字符 0 与 数字 0 很 容易 混淆, 所 以 常 使 用 字符 Q 作为 八进制 数 的 后 级 ;后 级 H 表示 这 个 
数 是 十 六 进 制 数 (Hexadecimal) ;而 后 级 D 表示 这 个 数 是 十 进 制 数 (Decimal)。 十 进 制 数 在 
书写 时 后 级 了 D 可 以 省 略 , 其 他 进 制 在 书写 时 后 级 一 般 不 可 省 略 。 例 如 ,有 4 个 数 分 别 为 
375D、101B、76Q、A17H, 从 后 级 字母 就 可 以 知道 它们 分 别 是 十 进 制 数 、 二 进 制 数 .八进制 数 
和 十 六 进 制 数 。 

计算 机 系统 设计 师 和 程序 员 更 钟情 于 采用 程序 设计 语言 的 记号 来 表示 不 同 进 制 的 数 ， 
这 就 是 前 绥 表 示 法 。 例 如 ,在 C 语言 中 ,八进制 常数 以 前 级 0 开始 ,十 六 进 制 常数 以 前 组 0x 
开始 。 


2.1.2 无 符号 数 和 带 符 号 数 
所 谓 无 符号 数 ,就 是 整个 机 器 字 长 的 全 部 二 进 制 位 均 表示 数值 位 (没有 符号 位 ) ,相当 于 
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数 的 绝对 值 。 例 如 : 

Ni 二 01001 表示 无 符号 数 9。 

N: 王 11001 表示 无 符号 数 25。 

机 需 字 长 为 2 十 1 位 的 无 符号 数 的 表示 范围 是 0 一 (2 汪 一 1) ,此 时 二 进 制 的 最 高 位 也 是 
数值 位 ,其 权 值 等 于 2"。 寿 字 长 为 8 位 , 则 数 的 表示 范围 为 0 一 255。 

一 般 计 算 机 中 都 设置 有 一 些 无 符号 数 的 运算 和 处 理 指令 。 例 如 ,Intel 8086 中 的 MUL 
和 DIV 指令 就 是 无 符号 数 的 乘法 和 除法 指令 ,还 有 一 些 条 件 转移 指令 也 是 专门 针对 无 符号 
数 的 。 

然而 ,大 量 用 到 的 数据 还 是 融 符 号 数 , 即 正 、 负 数 。 在 日 常生 活 中 用 符号 十 、 一 加 绝对 值 
来 表示 数值 的 大 小 ,用 这 种 形式 表示 的 数值 在 计算 机 技术 中 称 为 “ 真 值 ”。 

对 于 数 的 符号 十 或 一 ,计算 机 是 无 法 识别 的 ,因此 需要 把 符号 数码 人 化。 通常, 约定 二 进 
制 数 的 最 高 位 为 符号 位 ,0 表示 正 号 ,1 表示 负 号 。 这 种 在 计算 机 中 使 用 的 表示 数 的 形式 称 
为 机 器 数 ,常见 的 机 器 数 有 原 码 、 反 人 码 、 补 码 等 不 同 的 表示 形式 。 

带 符号 数 的 最 高 位 被 用 来 表示 符号 位 ,而 不 再 表示 数值 位 。 前 例 中 的 Ni、N; 在 这 里 的 

Ni 一 01001 表示 十 9。 

N, 二 11001 根据 机 器 数 的 不 同形 式 表 示 不 同 的 值 ,如 是 原 码 则 表示 一 9, 知 是 补 码 则 表 
示 一 7, 耕 是 反 人 码 则 表示 一 6。 

为 了 能 正确 地 区 别 出 丰 值 和 各 种 机 强 数 ,本 书 用 X 表示 真 值 ,LX jr 表示 原 码 ,|LX 外 表 
示 补 码 ,LX JE 表示 反 码 。 


2.1.3 原 码 表示 法 


原 码 表示 法 是 一 种 最 简单 的 机 器 数 表示 法 ,其 最 高 位 为 人 符号 位 ,符号 位 为 0 时 表示 该 数 
为 正 , 符 号 位 为 1 时 表示 该 数 为 负 ,数值 部 分 与 真 值 相同 。 

硅 真 值 为 纯 小 数 , 它 的 原 码 形式 为 X.. X1 X，…X, ,其 中 X, 表示 符号 位 。 原 码 的 定 
义 为 : 

_(X 0 委 X 一 ] 
Ca 人 Xi x 一 1<X 委 0 
假设 机 带 数 长 度 为 5 位 , 则 有 : 
例 2-1 X=0.0110 [X00I110 
X=—0.0110 [Xjn=1l—X=1—(—0.0110)=1++0.0110=1.0110 

右 丰 值 为 纯 整 数 , 它 的 原 码 形式 为 X,X1X，,…X, ,其 中 X, 表示 符号 位 。 原 码 的 定义 为 : 


于 0 
[Xj 二 
2" 一 X 一 2" 十 |X| 一 2"”<X 委 0 
例 2-2 X=1101 [Xjr=X=01101 


X= 一 1101 [X 一 2" 一 X 一 2 一 (一 1101) 王 10000 十 1101 王 11101 
在 原 码 表示 中 , 真 值 0 有 两 种 不 同 的 表示 形式 : 
[十 0 原生 00000 
[—0 |]rm = 10000 
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原 码 表示 法 的 优点 是 直观 易 履 , 机 融 数 和 真 值 间 的 相互 转换 很 容易 ,用 原 码 实 现 来 、 除 
运算 的 规则 很 简单 ;缺点 是 实现 加 、 减 运算 的 规则 较 复 杂 。 


2.1.4 补 码 表示 法 
1. 模 和 同 余 


为 了 理解 补 码 表示 法 ,首先 需要 引入 模 和 同 余 的 概念 。 

模 (Module) 是 指 一 个 计量 需 的 容量 ,可 用 M 表示 。 例 如 ,一 个 4 位 的 二 进 制 计 数 需 , 当 
计数 需 从 0 计 到 15 之 后 ,再 加 1, 计 数值 又 变 为 0。 这 个 计数 需 的 容量 M 二 2 二 16, 即 模 为 
16。 由 此 可 见 , 纯 小 数 的 模 为 2, 一 个 字 长 为 2 十 1 位 的 纯 整 数 的 模 为 2 。 

同 余 概 念 是 指 两 个 整数 A 和 B 除 以 同一 个 正 整数 M ,所 得 余数 相同 , 则 称 A 和 B 对 M 
同 余 , 即 A 和 B 在 以 M 为 模 时 是 相等 的 ,可 写成 如 下 形式 : 

A=B (mod MD) 

对 钟表 而 言 ,其 模 M 二 12, 故 4 点 和 和 16 点 ,5 点 和 17 点 …… 均 是 同 余 的 ,它们 可 以 写成 

如 下 形式 : 
4=16 (mod 12), 5=17 (mod 12) 

利用 模 和 同 余 概念 的 补 码 表示 法 在 进行 算术 运算 时 可 以 使 减法 运算 转化 成 加 法 运算 ， 
从 而 简化 机 器 的 运算 器 电路 。 

假设 时 钟 停 在 8 点 ,而 现在 正确 的 时 间 是 6 点 ,这 时 拨 准 时 钟 的 方法 有 如 下 两 种 : 

QD 将 分 针 倒 着 旋转 两 圈 ( 即 时 钟 倒 拨 2 小 时 )8 一 2 二 6( 做 减法 )。 

@ 将 分 针 正 着 旋转 10 圈 ( 即 时 钟 正 拨 10 小 时 )8 十 10=6 (mod 12) (做 加 法 )。 


此 时 ， 8 一 2 二 8 十 10 (mod 12) 
设 : A=—2, B=10 

10 12—2 一 2 
Wl . 10_ 上 2 一 “一 1 二 2 
则 ;: 12™ 12 “11 


故 一 2 和 10 同 余 。 同 余 的 两 个 数 具 有 互补 关系 ,一 2 与 10 对 模 12 互补 ,也 可 以 说 一 2 
的 补 数 是 10( 以 12 为 模 ) 。 

可 见 , 只 要 确定 了 “ 模 ”, 就 可 找到 一 个 与 负数 等 价 的 正 数 (该 正 数 即 为 负数 的 补 数 ) 来 代 
蔡 此 负数 ,而 这 个 正 数 可 以 用 模 加 上 负数 本 身 求 得 ,这 样 就 可 把 减法 运算 用 加 法 实现 了 。 

例 2-3 9 一 5=9 十 (一 5)=9 十 (12 一 5)=9 十 7=4 (mod 12) 

例 2-4 65 一 25 一 65 十 (一 25) 一 65 十 (100 一 25) 一 65 十 75 一 40 (mod 100) 

将 补 数 的 概念 用 到 计算 机 中 , 便 出 现 了 补 码 这 种 机 需 数 。 


X 0<X< 
[ X 让 一 人 (mod M) 
NM 十 X 0 


2. 补 码 表示 


补 码 的 符号 位 表示 方法 与 原 码 相同 ,其 数值 部 分 的 表示 与 数 的 正 负 有 关 : 对 于 正 数 , 数 
值 部 分 与 真 值 形式 相同 ;对 于 负数 ,将 真 值 的 数值 部 分 按 位 取 反 , 且 在 最 低位 上 加 1。 


EE 
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奇 真 值 为 纯 小 数 , 它 的 补 码 形式 为 XX.. XiX…X, ,其 中 X, 表 示 符 号 位 。 补 码 的 定 
义 为 : 


例 2-5 X=0.0110 [Xj 二 X=0.0110 

X= 一 0.0110 [六 六 二 2 十 二 2 十 (一 0.0110)==10 一 0.0110==1. 1010 
若 真 值 为 纯 整 数 , 它 的 补 码 形式 为 X,X1X，…X, ,其 中 X, 表示 符号 位 。 补 码 的 定义 为 : 

0 三 X= 
| | -2<X<o m2  ) 

例 2-6 X=1101 [X]# 王 X 一 01101 

X= 一 1101 “[LX]# = 三 2"+1 十 X 王 2 十 (一 1101) 王 100000 一 1101 三 10011 
在 补 码 表示 中 , 真 值 0 的 表示 形式 是 唯一 的 : 

[二 0j 杀 二 [一 0 六 三 00000 


3. 由 真 值 \ 原 码 转 换 为 补 码 


采用 补 码 系统 的 计算 机 需要 将 真 值 或 原 码 形式 表示 的 数据 转换 为 补 码 形式 ,以 便于 运 
算 关 对 其 进行 运算 。 通 第 ,从 原 码 形式 人 手 来 求 补 码 。 
当 X 为 正 数 时 ,LX] 和 王 LX] 奈 王 X。 
当 X 为 负数 时 ,其 [Xj 等 于 把 LX jr 除去 符号 位 外 的 各 位 求 反 后 最 低位 青 加 1 。 
反之 , 当 X 为 负数 时 ,已 知 LXJji, 也 可 通过 对 其 除 符 号 位 外 的 各 位 求 反 加 1 来 求 得 
[Xj 吕 。 
当 X 为 负数 时 , 巾 LX] 原 转换 为 LX 和 的 另 一 种 更 有 效 的 方法 是 : 日 低位 问 高 位 ,尾数 的 
第 一 个 1 及 其 右 部 的 0 保持 不 变 , 左 部 的 各 位 取 反 ,符号 位 保持 不 变 。 
例 2-7 [Xj]«m 二 1.1110011000 
[XJ]#=1.000110 1000 
不 变 取 反 不 变 
这 种 方法 避免 了 加 1 运算 ,是 实际 求 补 线路 逻辑 实现 的 依据 。 
对 于 负数 ,也 可 以 直接 由 真 值 X 转换 为 LX jh，, 其 方法 更 简单 : 数值 位 日 低位 问 高 位 , 尾 
数 的 第 一 个 1 及 其 右 部 的 0 保持 不 变 , 左 部 的 各 位 取 反 , 负 号 用 1 表示 。 
例 2-8 X= 一 0.1010001010 
[X]#=1.0101110110 


2.1.5 反 码 表示 法 


反 码 表示 法 与 补 码 表示 法 有 许多 类 似 之 处 ,对 于 正 数 ,数值 部 分 与 真 值 形式 相同 ;对 于 
负数 ,将 真 值 的 数值 部 分 按 位 取 反 。 反 码 与 补 码 的 区 别 是 末 位 少 加 一 个 1, 因 此 很 容易 从 补 
码 的 定义 推出 反 公 的 定义 。 

右 真 值 为 纯 小 数 , 它 的 反 码 形式 为 X.. Xi X，…X, ,其 中 X, 表 示 符 号 位 。 反 码 的 定 
义 为 : 
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例 2-9 X=0.0110 [Xjs=X=0.0110 
X=—0.0110 [Xjs=(2—2™") 十 X=(2 一 2~) 十 X 
=]1.1111 十 (一 0.0110)=1.1111 一 0.0110=1. 1001 
右 真 值 为 纯 整 数 , 它 的 反 码 形式 为 X,;X1X,…X, ,其 中 X, 表示 符号 位 。 反 码 的 定义 为 : 
< n 
Cx {Cm tx ee we 
例 2-10 X=1101 [Xjs=X=01101 
X=—1101 [Xjx=(C(2"—1) TX= (2—]1) 十 (一 1101) 
=11111 一 1101==10010 
在 反 码 表示 中 , 真 值 0 也 有 两 种 不 同 的 表示 形式 : 
[二 0j]5s 二 00000 
[—0js=11111l 


2.1.6 3 种 机 器 数 的 比较 与 转换 
1. 比较 


原 码 、 补 码 和 反 码 这 3 种 机 器 数 既 有 共同 点 ,又 有 各 自 不 同 的 性 质 , 主 要 区 别 有 以 下 几 点 : 

QW 对 于 正 数 它们 都 等 于 真 值 本 身 ,对 于 负数 则 各 有 不 同 的 表示 。 

GO 最 高 位 都 表示 符号 位 , 补 码 和 反 码 的 符号 位 可 作为 数值 位 的 一 部 分 看 待 , 和 数值 位 
一 起 参加 运算 ;但 原 码 的 符号 位 不 允许 和 数值 位 同等 看 待 ,必须 分 开 进 行 处 理 。 

G) 对 于 真 值 0, 原 码 和 反 码 各 有 两 种 不 同 的 表示 形式 ,而 补 码 只 有 唯一 的 一 种 表示 形式 。 

@ 原 码 ` 反 码 表示 的 正 、 负 数 范 围 相 对 零 来 说 是 对 称 的 ;但 补 码 负数 表示 范围 较 正 数 表 示 
范围 宽 , 能 多 表示 一 个 最 负 的 数 ( 绝 对 值 最 大 的 负数 ) ,其 值 等 于 一 2 ( 纯 整数 ) 或 一 1( 纯 小 数 )。 

表 2-1 列 出 了 真 值 与 3 种 机 需 数 间 的 对 照 , 表 中 设 字 长 等 于 4 位 ( 含 1 位 符号 位 )。 


表 2-1 和 3 种 机 器 数 间 的 对 照 


LXj# 


0000 
1111 
1110 
1101 
1100 
1011 
1010 
1001 
1000 
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在 表 2-1 中 ,请 特别 注意 1000 这 个 代码 , 当 其 为 原 码 时 ,对 应 的 真 值 是 一 0; 当 其 为 补 码 
时 ,对 应 的 真 值 是 一 8; 当 其 为 反 码 时 ,对 应 的 真 值 是 一 7。 


2. 转换 
3 种 不 同 机 需 数 以 及 真 值 之 间 的 转换 关系 如 图 2-1 所 示 。 


[9] 补 


世 


付 与 位 不 变 一 不 变 (X=0) 
sa +1(Xs= 1) 


符号 +/- 变 成 01 
SR 数值 位 不 变 im 


四 


数值 位 < 让 反 (这 1 


区 ] 反 


日 


2-1 3 种 不 同 机 器 数 及 真 值 间 的 转换 关系 


从 图 2-1 可 看 出 , 真 值 X 与 补 码 或 反 人 码 之 间 的 转换 通常 是 通过 原 码 实现 的 ,对 于 已 熟 
练 掌握 转换 方法 的 读者 ,也 可 以 直接 完成 真 值 与 补 码 或 反 人 码 之 间 的 转换 ，。 

如 果 已 知 机 需 的 字 长 , 则 机 需 数 的 位 数 应 补 够 相应 的 位 数 。 例 如 , 设 机 器 字 长 为 8 
位 , 则 : 


X 一 1011 [Xj]n =00001011 [Xi 一 00001011 [Xj]s =00001011 
X 一 一 1011 [XJ]x=1000101]1 [X]# 王 11110101 [Xjs=11110100 
X=0. 1011 [Xj]m=0.1011000 [Xj]#=0.1011000 [XJ]as=0.1011000 


么 一 一 0. 1011 [Xj 二 1. 1011000 [Xj] 宁 二 1.0101000 [Xjas=1.0100111 


2.2 机 希 数 的 定 总 表示 与 浮 总 表示 
计算 机 在 进行 算术 运算 时 ,需要 指出 小 数 点 的 位 置 。 根 据 小 数 点 的 位 置 是 否 固定 ,在 计 
算 机 中 有 两 种 数据 格式 : 定点 表示 和 浮 点 表示 。 
2.2.1 定点 表示 法 


在 定点 表示 法 中 约定 : 所 有 数据 的 小 数 点 位 置 固定 不 变 。 通常, 把 小 数 点 固定 在 有 效 
数位 的 最 前 面 或 末尾 ,这 就 形成 了 两 类 定点 数 。 


1. 定点 小 数 


定点 小 数 即 纯 小 数 ,小 数 点 的 位 置 固 定 在 最 高 有 效 数 位 之 前 、 符 号 位 之 后 ,如 图 2-2 所 
示 。 和 定点 小 数 的 小 数 点 位 置 是 隐 含 约定 的 ,小 数 点 并 不 需要 真正 地 占据 一 个 二 进 制 位 。 
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于 位 数值 位 


第 

2 

章 
| 小 数 点 位 置 ( 隐 含 ) El 


数 符 


图 2-2 定点 小 数 格式 
= A,=0,Al==1],A,=]1,*.…,A,=] 时 ,X 为 最 大 正 数 ,其 真 值 为 : 


入 最 大 E 数 一 1] 一 2 ” 
当 X= 二 0,Xi1 二 0,…, 头 ,-1 二 0,XX, 二 1 时 ,X 为 最 小 正 数 ,其 真 值 为 : 
入 最 小 正 数 一 2 “ 
当 X,.=1, 表 示 X 为 负数 时 ,情况 要 稍微 复杂 一 些 , 这 是 因为 在 计算 机 中 带 符 号 数 可 用 
补 人 码 表 示 , 也 可 用 原 码 表 示 , 原 码 和 补 码 的 表示 范围 有 一 些 差别 。 
若 机 器 数 为 原 码 , 当 X,. 一 X, 均 等 于 1 时 ,X 为 绝对 值 最 大 的 负数 ,其 真 值 为 : 
入 绝对 值 最 大 负数 一 一 (1 一 2 “) 
右 机 融 数 为 补 码 , 当 X,.=1,Xi 一 X, 均 等 于 0 时,X 为 绝对 值 最 大 的 负数 ,其 真 值 为 : 
入 绝对 值 最 大 负数 一 一 | 
综 上 所 述 , 设 机 带 字 长 有 nn 十 1 位 , 原 码 定 点 小 数 的 表示 范围 为 一 (1 一 2 ”) 一 (1 一 2“)， 
补 码 定点 小 数 的 表示 范围 为 一 1 一 (1 一 2“")。 硅 字 长 为 8 位 , 原 码 定点 小 数 的 表示 范围 


. 127 127 三 示范 围 127 
> 一 a 目 > =— A 


2. 定点 整数 
定点 整数 即 纯 整数 ,小 数 点 位 置 隐 含 固定 在 最 低 有 效 数位 之 后 ,如 图 2-3 所 示 。 
n 位 数值 位 


小 数 点 位 置 ( 隐 含 ) 
数 符 
2-3 定点 整数 格式 
根据 前 述 方法 不 难 推出 : 


双 最 大 正 数 一 《2 一 1) 
入 最 小 正 数 一 ] 
站 名 对 值 最 大 负数 二 一 (2" 一 1)( 原 码 表 示 时 ) 
和 站 对 值 最 大 负数 一 一 2"( 补 码 表示 时 ) 
综 上 所 述 , 设 机 带 字 长 为 2 十 1 位 , 原 码 定点 整数 的 表示 范围 为 一 (2 一 1) 一 (2 一 1), 补 
码 定 点 整数 的 表示 范围 为 一 2 一 (2 一 1)。 若 字 长 为 8 位 , 原 码 定点 整数 的 表示 范围 
为 一 127 一 127, 补 码 定 点 整数 的 表示 范围 为 一 128 一 127。 
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在 定点 表示 法 中 ,参加 运算 的 数 以 及 运算 的 结果 都 必须 保证 落 在 该 定点 数 所 能 表示 的 
数值 范围 内 ,如 结果 大 于 最 大 正 数 和 小 于 绝对 值 最 大 的 负数 ,统称 为 “溢出 ”。 这 时 计算 机 将 
暂时 中 止 运算 操作 ,而 进行 溢出 处 理 。 

需要 说 明 的 是 ,现代 计算 机 中 大 多 只 采用 整数 数据 表示 ,小 数 则 通过 浮 点 数 表示 来 
实现 。 


2.2.2 浮 点 表示 法 


在 科学 计算 中 ,计算 机 处 理 的 数 往往 是 混合 数 , 它 既 有 整数 部 分 又 有 小 数 部 分 ,如 果 要 
将 这 些 数 变 为 上 述 约定 的 两 种 定点 数 形式 ,就 必须 在 运算 前 设 定 一 个 比例 因子 ,把 原始 的 数 
缩小 成 定点 小 数 或 扩大 成 定点 整数 ,运算 后 的 结果 还 需要 根据 比例 因子 还 原 成 实际 的 数值 ， 
这 会 给 编程 市 来 很 多 有 麻烦。 男 外 ,在 运算 中 常常 会 遇 到 非常 大 或 非常 小 的 数值 ,如 果 用 同样 
的 比例 因子 来 处 理 ,很 难 兼 顾 数 值 范 围 和 运算 精度 的 要 求 。 因 此 ,在 计算 机 中 引入 了 浮 点 数 
表示 。 

让 小 数 点 的 位 置 根据 需要 而 浮动 ,这 就 是 浮 点 数 。 例 如 : 

N=MXxXr: 

其 中 ,r 是 浮 点 数 阶 码 的 抵 , 与 尾数 的 基数 相同 ,通常 r 二 2。E 和 M 痢 是 市 从 号 的 定点 数 ,E 
称 为 阶 码 (Exponent) ,M 称 为 尾数 (Mantissa)。 在 大 多 数 计 算 机 中 ,尾数 为 纯 小 数 , 和 常用 原 
码 或 补 码 表示 ; 阶 码 为 纯 整 数 , 和 常用 移 码 或 补 码 表示 。 

浮 点 数 的 一 般 格式 如 图 2-4 所 示 , 浮 点 数 的 底 是 隐 含 的 ,在 整个 机 融 数 中 不 出 现 。 阶 码 
的 符号 位 为 e;, 阶 码 的 大 小 反映 了 在 数 NN 中 小 数 点 的 实际 位 置 ;尾数 的 符号 位 为 m;, 它 也 是 
整个 浮 点 数 的 符号 位 ,表示 了 该 浮 点 数 的 正 、 负 。 

浮 点 数 的 表示 范围 主要 由 阶 码 的 位 数 来 决定 ,有 效 数 字 的 精度 主要 由 尾数 的 位 数 来 决 
定 ,下面 介绍 这 两 个 问题 。 


1. 浮 点 数 的 表示 范 围 


设 茶 浮 点 数 的 格式 如 图 2-4 所 示 , 和 nn 分 别 表示 阶 码 和 尾数 的 数值 位 位 数 (不 包括 符 
号 位 ) ,尾数 和 阶 码 均 用 补 人 码 表示 。 


阶 码 部 分 五 


2-4 浮 点 数 的 一 般 格式 


当 e, 二 0,m, 二 0, 阶 码 和 尾数 的 数值 位 各 位 全 为 1( 即 阶 码 和 尾数 都 为 最 大 正 数 ) 时 ,该 
浮 点 数 为 最 大 正 数 : 
XX 大 EV 二 (1 一 2*) X27! 
当 e, 二 1,m, 王 0, 尾数 的 最 低位 mm, 二 1, 其 余 各 位 为 0( 即 阶 码 为 绝对 值 最 大 的 负数 , 尾 
数 为 最 小 正 数 ) 时 ,该 浮 点 数 为 最 小 正 数 : 
Wn 
当 e, 二 0, 阶 码 的 数值 位 为 全 1; 且 mm, 二 1, 尾 数 的 数值 位 为 全 0( 即 阶 码 为 最 大 正 数 , 尾 
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数 为 绝对 值 最 大 的 负数 ) 时 ,该 浮 点 数 为 绝对 值 最 大 负数 : 


> EU 一 王浆 关 一 


2. 规格 化 浮 点 数 


为 了 提高 运算 的 精度 ,需要 充分 地 利用 尾数 的 有 效 数 位 ,通常 采取 浮 点 数 规格 化 形式 ， 
即 规定 尾数 的 最 高 数位 必须 是 一 个 有 效 值 。 

一 个 浮 点 数 的 表示 形式 并 不 是 唯一 的 。 例 如 , 二进制 数 0. 0001101 可 以 表示 为 
0. 001101 X27"% .0.01101 X27 0,1101 X27 1...... 而 其 中 只 有 0. 1101 X27- 是 规格 化 数 ， 
这 就 如 同 十 进 制 实数 中 的 科学 标识 法 一 样 。 

规格 化 浮 点 数 的 尾数 M 的 绝对 值 应 在 下 列 范 围 内 : 


T<IMI<I 


如 果 /一 2, 则 有 二 壹 1M| 二 1。 在 尾数 用 原 码 表示 时 ,规格 化 浮 点 数 的 尾数 的 最 高 数位 
总 等 于 1。 在 尾数 用 补 码 表示 时 ,规格 化 浮 点 数 应 满足 尾数 最 高 数位 与 符号 位 不 同 
Cm,@m 二 ]D), 即 当 记 过 M 二 1 时 ,应 有 0.1X X… XX 形式 ; 当 一 1<M 二 一 目 时 ,应 有 
1.0XX…X 形 式 ，。 

注意 ; 当 M 一 一 广 时 ,对 于 原 码 来 说 这 是 一 个 规格 化 数 ,而 对 于 补 码 来 说 这 不 是 一 个 规 


格 化 数 ; 当 M= 二 一 1 时 ,对 于 原 码 来 说 这 将 无 法 表示 ,而 对 于 补 码 来 说 这 是 一 个 规格 化 数 。 

当 e, 二 1,m, 二 0, 尾 数 的 最 高 位 m 二 1, 其 余 各 位 为 0 时 ,该 浮 点 数 为 规格 化 的 最 小 
正 数 : 

站 规格 化 的 最 小 正 数 二 2! X 2 一 2 

规格 化 的 最 小 正 数 大 于 非 规格 化 的 最 小 正 数 。 

非 规格 化 浮 点 数 需要 进行 规格 化 操作 才能 变 成 规格 化 浮上 点 数 。 所 谓 规格 化 操作 ,就 是 
通过 相应 地 调整 一 个 非 规格 化 浮 点 数 的 尾数 和 阶 码 的 大 小 ,使 非 零 的 浮 点 数 在 尾数 的 最 高 
数位 上 保证 是 一 个 有 效 值 ,具体 的 操作 方法 留待 第 4 草 介 绍 。 

表 2-2 列 出 了 浮 点 数 的 一 些 典 型 值 , 设 阶 码 和 尾数 均 用 补 码 表示 , 阶 码 共 & 十 1 位 ( 含 一 
位 阶 符 ) ,尾数 共 n 十 1 位 ( 含 一 位 尾 符 )。 

表 2-2 浮 点 数 的 典型 什 


浮 点 数 代码 


浮 点 数 真 值 
最 大 正 数 | 要 (] —2-") X24-1 
绝对 值 最 大 负数 “1 —1X2*-! 
最 小 正 数 0 2—n x 2 一 此 
规格 化 的 最 小 正 数 0 2-1 X 2 一 此 
绝对 值 最 小 负数 0 — 2-n X2 一 上 
规格 化 的 绝对 值 最 小 负数 0 — (2-1+2-*)X2-* 


和 
2 
章 
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当 运 算 结 果 大 于 最 大 正 数 时 称 为 正 上 洲 ,小 于 绝对 值 最 大 负数 时 称 为 负 上 洲 , 正 上 洲 和 
负 上 洪 统 一 称 为 上 洲 ,数据 一 旦 产生 上 洲 , 计 算 机 必须 中 止 运 算 操 作 , 进 行 溢出 处 理 。 当 运 
算 结 果 在 0 至 规格 化 最 小 正 数 之 间 称 为 正 下 洲 ,在 0 至 规格 化 的 绝对 值 最 小 负数 之 间 称 为 
负 下 深 , 正 下 洪 和 人 负 下 洲 统 一 称 为 下 洲 ,数据 一 旦 出 现下 溢 ,计算 机 一 般 不 做 任何 处 理 , 仅 仅 
置 成 机 天 零 即 可 。 

只 要 浮 点 数 的 尾数 为 0, 不 论 阶 码 为 何 值 ,一 般 也 当 作 机 融 堆 处理 。 为 了 保证 浮 点 数 0 
表示 形式 的 唯一 性 ,规定 了 机 天 去 的 标准 格式 , 即 : 尾数 为 0, 阶 码 为 最 小 值 ( 绝 对 值 最 大 的 
负数 )。 


2.2.3 浮 点 数 阶 码 的 移 码 表示 法 


浮 点 数 的 阶 码 是 带 符 号 的 定点 整数 ,理论 上 说 它 可 以 用 前 面 提 到 的 任何 一 种 机 器 数 的 
表示 方法 来 表示 ,但 在 多 数 通用 计算 机 中 , 它 还 采用 另 一 种 编码 方法 一 一 移 码 表示 法 。 
移 码 就 是 在 真 值 X 基础 上 加 一 个 常数 ,这 个 常数 被 称 为 偏 置 值 ,相当 于 XX 在 数 轴 上 癌 
正方 向 偏 移 了 若干 单位 ,这 就 是 “ 移 码 ” 一 词 的 由 来 , 移 码 也 可 称 为 增 码 或 偏 码 。 即 : 
[Xj$ 二 偏 置 值 十 X 
图 2-5 是 移 码 和 真 值 的 映射 图 ,此 时 偏 置 值 等 于 2”。 


对 于 字 长 为 8 位 的 定点 整数 ,如 果 偏 置 值 为 yi 
2 , 则 有 : 到 2 ,/ 移 
例 2-11 X=1101101 py 2 4 
[X]z 一 2 十 1101101 一 10000000 十 1101101 = 
=11101101 < ee 
而 此 时 [Xj 二 01101101。 图 2-5 ” 移 码 和 真 值 的 映射 


例 2-12 X= 一 1101101 

[XI]z 王 2 十 (一 1101101) 志 10000000 一 1101101 二 00010011 
而 此 时 [XX 二 10010011。 
表 2-3 给 出 了 偏 置 值 为 2 的 移 码 与 补 码 和 真 值 之 间 的 关系 。 


表 2-3 偏 置 值 为 2 的 移 码 、 补 码 和 真 值 之 间 的 关系 


真 值 X( 十 进 制 ) 真 值 X( 二 进 制 ) [ws 


一 128 一 10000000 10000000 00000000 
一 127 一 1111111 10000001 00000001 
一 ] 一 0000001 LIELLLL 01111111 

0 0000000 00000000 10000000 


1 0000001 00000001 10000001 


127 1111111 1111111 11111111 


从 表 2-3 中 可 以 看 出 这 种 移 码 具有 以 下 特点 : 
QD 在 移 码 中 ,最 高 位 为 0 表示 负数 ,最 高 位 为 1 表示 正 数 ,这 与 原 码 、 补 码 以 及 反 码 的 
符号 位 取 值 正好 相反 。 
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多 移 码 全 为 0 时 , 它 所 对 应 的 真 值 最 小 ;全 为 1 时 , 它 所 对 应 的 真 值 最 大 。 因 此 , 移 码 
的 大 小 直观 地 反映 了 真 值 的 大 小 ,这 将 有 助 于 两 个 浮 点 数 进行 阶 码 的 大 小 比较 。 

@) 真 值 0 在 移 码 中 的 表示 形式 也 是 唯一 的 , 即 [ 十 0 闪 二 [一 0j 阁 二 10000000。 

网 移 码 把 真 值 映射 到 一 个 正 数 域 ,所 以 可 将 移 码 视 为 无 符号 数 ,直接 按 无 符号 数 规则 
比较 大 小 。 

@) 同一 数值 的 移 码 和 补 码 除 最 高 位 相反 外 ,其 他 各 位 相同 。 

浮 点 数 的 阶 码 常 采用 移 码 表示 的 最 主要 的 原因 有 两 个 : 

QO 便于 比较 浮 点 数 的 大 小 。 阶 码 大 的 ,其 对 应 的 真 值 就 大 ; 阶 码 小 的 , 则 对 应 的 真 值 
就 小 。 

@@ 简化 机 器 中 的 判 零 电路 。 当 阶 码 全 为 0, 尾数 也 全 为 0 时 ,表示 机 器 零 。 


2.2.4 浮 点 数 妊 数 的 基数 
1. 尾数 基数 大 小 的 选择 


已 知 , 浮 点 数 N 二 MXr*”。 其 中 ,r 是 阶 码 的 底 , 又 称 为 尾数 的 基数 ,在 前 面 的 讨论 中 ,r 
都 等 于 2, 而 实际 上 可 以 等 于 4,8,16…… 

浮 点 数 尾数 基数 的 选择 对 浮 点 数 的 特性 起 着 主要 作用 , 它 既 影响 浮 点 运算 的 精度 ,也 影 
啊 数 值 的 表示 范围 。 采 用 较 大 的 ~ 值 ,在 阶 码 位 数 相同 的 情况 下 ,可 以 扩大 浮 点 数 的 表示 范 
围 。 假 定 某 浮 点 数字 长 为 32 位 , 阶 码 部 分 ( 阶 符 和 阶 码 数值 位 ) 共 8 位 ,尾数 部 分 ( 尾 符 与 尾 
数 数值 位 ) 共 24 位 , 均 用 补 码 表示 。 

若 r= 二 2, 则 规格 化 浮 点 数 的 表示 范围 为 一 1 X2” 达 XX 三 (1 一 2-”) X27 ,最 小 正 数 为 
2 

若 r= 二 16, 则 规格 化 浮 点 数 的 表示 范围 为 一 1 X16'” 志 XX 三 (1 一 2-””) X16 ,最 小 正 数 
yn 

事实 上 ,在 以 r 进 制 为 尾数 基数 的 浮 点 数 中 , 当 尾 数 的 位 数 为 二 进 制 位 时 ,就 相当 于 
进 制 的 尾数 有 个 数位 ,其 中 二 n/|logsr 1 


前 面 已 经 提 到 ,规格 化 也 是 和 基数 + 有 关系 的 ,规格 化 浮 点 数 的 尾数 |M| 应 在 [ 士 ,1 ) 范 


围 内 。 若 现在 尾数 M 二 0.0001X…X ,对 于 基数 一 2 的 浮 点 数 来 说 ,这 是 一 个 非 规格 化 数 ， 
需要 进行 规格 化 操作 ;而 对 于 ”= 一 16 的 浮 点 数 来 说 ,这 已 是 一 个 规格 化 数 了 ,无 须 再 进行 规 
格 化 操作 。 规 格 化 操作 是 以 7 为 尺度 进行 移 位 的 ,尾数 每 左 移 (或 右 移 )llogsr 位 , 阶 码 将 减 
(或 加 )1。 

不 同 计算 机 的 7 值 可 能 不 同 。 例 如 ,PDP-11 和 IBM 370 的 短 浮 点 数 具 有 同样 的 格式 ， 
但 前 者 r= 二 2, 后 者 r= 二 16。 所 以 ,IBM 370 的 短 浮 点 数 比 PDP-11 的 短 浮 点 数 的 表示 范围 要 
大 ,但 相对 误差 也 较 大 。 


2. 尾数 基数 + 对 浮 点 数 特 性 的 影响 


改变 尾数 基数 7, 会 使 浮 点 数 的 特性 有 下 列 影响 : 
J 可 表示 数 的 范围 。 随 着 7 的 增 大 ,可 表示 数 的 范围 增 大 。 
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@ 可 表示 数 的 个 数 。 随 着 的 增 大 ,可 表示 数 的 个 数 增加 。 

G) 数 在 数 轴 上 的 分 布 。r 鳃 大 , 数 在 数 轴 上 的 分 布 密度 钝 黎 。 

由 可 表示 数 的 精度 。 随 着 7 的 增 大 ,可 表示 数 的 精度 单调 下 降 。 

@) 运算 中 的 精度 损失 。r 愈 大 ,尾数 右 移 的 机 会 愈 小 ,可 降低 运算 中 因 尾 数 右 移 所 造成 
的 精度 损失 。 

@) 运算 速度 。 增 大 ,将 使 运算 中 移 位 的 次 数 减少 ,运算 速度 可 以 提高 。 

以 上 6 条 中 ,第 山 . 急 . 包 、.@ 条 都 是 优点 ;但 第 包 、 由 条 则 是 缺点 。 为 了 扬长 避 短 ,在 巨 
型 大 型 和 中 型 计算 机 上 , 浮 点 数 尾数 基数 x 宜 取 大 些 , 而 在 微型 和 小 型 计算 机 上 ,x 值 宜 取 
小 些 。 


2.2.5 IEEE 754 标准 浮 点 数 


在 目前 常用 的 80x86 系列 微型 计算 机 中 ,通常 设 有 支持 浮 点 运算 的 部 件 。 在 这 些 机 器 
中 的 浮 点 数 采 用 IEEE 754 标准 , 它 与 前 面 介 绍 的 浮 点 数 格式 有 一 些 差别 。 
按 IEEE 754 标准 , 篆 用 的 浮 点 数 的 格式 如 图 2-6 所 示 。 


数 符 。 阶 码 部 分 ,用 移 码 表示 尾数 数值 位 
We 


尾数 部 分 ,用 原 码 表示 
2-6 按 IEEE 754 标准 ,常用 的 浮 点 数 格式 


IEEE 754 标准 中 有 3 种 形式 的 浮 点 数 ,它们 的 具体 格式 如 表 2-4 所 示 。 
表 2-4 ”IEEE 754 标准 中 的 3 种 浮 点 数 


Eee 
1 8 23 32 7FH 

本 本 本 呈 同 
1 15 64 80 3FFFH 


短 浮 点 数 又 称 为 单 精 度 浮 点 数 , 长 浮 点 数 又 称 为 双 精 度 浮 点 数 ,它们 都 采用 隐 含 尾数 最 
高 数位 的 方法 ,这 样 无 形 中 又 增加 了 一 位 尾数 。 临 时 浮 点 数 又 称 为 扩展 精度 浮 点 数 , 它 没有 

下 面 以 32 位 的 短 浮 点 数 为 例 , 讨 论 浮 点 代码 与 其 真 值 之 间 的 关系 。 最 高 位 为 数 和 从 位; 
其 后 是 8 位 阶 码 ,以 2 为 底 , 用 移 码 表示 , 阶 码 的 偏 置 值 为 127; 其 余 23 位 是 尾数 数值 位 。 
对 于 规格 化 的 二 进 制 浮 点 数 ,数值 的 最 高 位 总 是 1, 为 了 能 使 尾数 多 表示 一 位 有 效 值 , 可 将 
这 个 1 隐 含 ,因此 尾数 数值 实际 上 是 24 位 (1 位 隐 含 位 十 23 位 小 数位 )。 

注意 : 隐 含 的 1 是 一 位 整数 (即位 权 为 2")。 在 浮 点 格式 中 表示 出 来 的 23 位 尾数 是 纯 
小 数 , 用 原 码 表示 。 例 如 ,(12)io 王 (1100)，, 将 它 规格 化 后 结果 为 1. 1 X23, 其 中 整数 部 分 的 
“1” 将 不 存储 在 23 位 尾数 内 。 

阶 码 是 以 移 码 形式 存储 的 。 对 于 短 浮 点 数 , 偏 置 值 为 127(7FH); 长 浮 点 数 , 偏 置 值 为 
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1023(3FFH) 。 存 储 浮 点 数 阶 码 部 分 之 前 , 偏 置 值 要 先 加 到 阶 码 真 值 上 。 上 述 例子 中 , 阶 码 >， 
真 值 为 3, 故 在 短 浮 点 数 中 , 移 码 表示 的 阶 码 为 127 十 3 二 130(82H); 而 在 长 浮 点 数 中 , 移 码 本 
二 -于 
表示 的 阶 码 为 1023 十 3 二 1026(402H)。 
例 2-13 将 (100. 25)io 转 换 成 短 浮 点 数 格式 。 Ea 
Q@ 把 十 进 制 数 转换 成 二 进 制 数 。 
(100.25)10 =(1100100. 01)， 


GO 规格 化 二 进 制 数 。 
1100100. 01 王 1. 10010001 久 2 
QB 计算 出 阶 码 的 移 码 ( 偏 置 值 十 阶 码 真 值 )。 
1111111 十 110 和 10000101 
由 以 短 浮 点 数 格 式 存 储 该 数 。 
因为 ， 
符号 位 二 0 
阶 码 二 10000101 
尾数 二 10010001000000000000000 
所 以 , 短 浮 点 数 代码 为 : 
0;10000101;10010001000000000000000 
表示 为 十 六 进 制 的 代码 : 42C88000H。 
例 2-14 把 短 浮 点 数 C1C90000H 转换 成 十 进 制 数 。 
OO 将 十 六 进 制 代码 写成 二 进 制 形式 ,并 分 离 出 符号 位 、 阶 码 和 尾数 。 
因为 ， 
ClC90000H==11000001110010010000000000000000 
所 以 ， 
和 从 号 位 二 1 
阶 码 王 10000011 
尾数 二 10010010000000000000000 
@ 计算 出 阶 码 真 值 ( 移 码 减 去 偏 置 值 )。 
10000011 一 1111111 王 100 
G) 以 规格 化 二 进 制 数 形式 写 出 此 数 。 
1. 1001001 X 2 
@ 与 成 非 规格 化 二 进 制 数 形 式 。 
11001. 001 
人 @) 转换 成 十 进 制 数 ,并 加 上 符号 位 。 
(11001. 001), = (25. 125)io 
所 以 ， 
该 浮 点 数 王 一 25. 125 
通常 ,将 IEEE 754 短 浮 点 数 规格 化 的 数值 v 表示 为 : 
一 (一 1)SX(1. f) X21 
其 中 ,S 代表 符号 位 ,S=0 表示 正 数 ,S=1 表示 负数 ; 刁 为 用 移 码 表示 的 阶 码 ;了 是 尾数 的 小 
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为 了 表示 和 一 些 特殊 的 数值 ,E 的 最 小 值 0 和 最 大 值 255 将 留 作 他 用 。 因 此 ,最 小 正 
常 的 下 = 王 1, 最 大 正常 的 开 =254, 所 以 短 浮 点 数 的 阶 码 真 值 的 取 值 范围 为 一 126 一 127。 当 瓦 
和 mm 均 为 全 0 时 ,表示 机 天 零 ; 当 下 为 全 1,m 为 全 0 时 ,表示 士 ce。 


2.2.6 定点 、 浮 点 表示 法 与 定点 、 浮 点 计算 机 
1. 定点 、 浮 点 表示 法 的 区 别 


(1) 数值 的 表示 范围 

假设 定点 数 和 浮 点 数 的 字 长 相同 , 浮 点 表示 法 所 能 表示 的 数值 范围 将 远 远 大 于 定点 表 
示 法 。 

浮 点 数 阶 码 部 分 的 位 数 占 得 越 多 ,可 表示 的 数值 范围 就 越 大 ,但 是 相应 尾数 部 分 的 位 数 
将 减少 ,这 将 使 精度 下 降 。 因 此 , 阶 码 和 尾数 部 分 各 占 多 少 位 ,必须 全 面 权 衡 , 合 理 分 配 。 

注意 : 

e 不 管 定 点 数 还 是 浮上 点数 ,每 个 数值 都 对 应 于 数 轴 上 的 一 个 点 。 所 谓 数 的 表示 范围 , 实 

际 上 指 的 只 是 数 的 上 、 下限, 它们 之 间 是 一 些 不 连续 的 点 ,而 不 是 一 段 连续 的 区 间 。 
e 对 于 定点 整数 而 言 , 各 个 点 在 数 轴 上 的 分 布 是 均匀 的 ;而 对 于 浮 点 数 而 言 , 各 个 点 在 
数 轴 上 的 分 布 是 不 均匀 的 , 越 靠近 数 轴 的 原点 ,两 个 相 邻 数 之 间 的 距离 就 越 近 ， 

(2) 精度 

所 谓 精度 是 指 一 个 数 所 含有 效 数值 位 的 位 数 。 一 般 来 说 ,机 器 字 长 越 长 , 它 所 表示 的 数 
的 有 效 位 数 就 越 多 ,精度 就 越 高 。 对 于 字 长 相同 的 定点 数 与 浮 点 数 来 说 , 浮 点 数 虽然 扩大 了 
数 的 表示 范围 ,但 这 正 是 以 降低 精度 为 代价 的 ,也 就 是 数 轴 上 各 点 的 排列 更 稀 玖 了 。 

(3) 数 的 运算 

浮 点 数 包 括 阶 码 和 尾数 两 部 分 ,运算 时 不 仅 要 做 尾数 的 运算 ,还 要 做 阶 码 的 运算 ,而 且 
运算 结果 要 求 规格 化 。 因 此 , 浮 点 运算 要 比 定 点 运算 复杂 ,关于 具体 运算 的 讨论 将 在 第 4 草 
中 进行 。 

(4) 洲 出 处 理 

在 定点 运算 时 , 当 运 算 结果 超出 数 的 表示 范围 时 ,就 发 生 溢出 ;而 在 浮 点 运算 时 ,运算 结果 
超出 尾数 的 表示 范围 却 并 不 一 定 淤 出 ,只 有 当 阶 码 也 超出 所 能 表示 的 范围 时 , 才 发 生 溢出 。 


2. 定点 机 与 浮 点 机 


由 于 浮 点 数 的 运算 比较 复杂 ,所 以 并 不 是 所 有 的 计算 机 都 具有 浮 点 运算 功能 ,通常 可 以 
将 计算 机 分 为 以 下 几 种 。 

(1) 定点 机 

只 能 处 理 定 点 数 的 计算 机 称 为 定点 计算 机 ,低档 微机 和 某 些 专用 机 大 多 是 定点 机 。 在 
定点 机 中 机 融 指 令 访问 的 所 有 操作 数 都 是 定点 数 , 如 需 进 行 浮 点 运算 则 通过 执行 软件 子 程 
序 来 实现 。 

(2) 定点 机 十 浮 点 运算 部 件 

浮 点 运算 部 件 是 专门 用 于 对 计算 机 内 的 浮 点 数 进行 运算 的 部 件 ,系统 配置 了 浮 点 运算 
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部 件 ,将 使 浮 点 运算 速度 大 大 提高 。 许 多 微 、 小 型 计算 机 都 配 有 这 一 部 件 。 
(3) 浮 点 机 
具有 浮 点 运算 指令 和 基本 的 浮 点 运算 器 。 通 用 的 大 、 中 型 计算 机 多 为 浮 点 机 。 


2.3 非 数值 数据 的 表示 


非 数 值 数据 ,又 称 为 字符 数据 ,通常 是 指 字 符 、 字 符 串 、 图 形 符号 和 汉字 等 各 种 数据 , 它 


们 不 用 来 表示 数值 的 大 小 ,一 般 情况 下 不 对 它们 进行 算术 运算 。 
2.3.1 字符 和 字符 串 的 表示 
1. ASCII 字符 编码 


由 于 计算 机 内 部 只 能 识别 和 处 理 二 进 制 代码 ,所 以 字符 必须 按照 一 定 的 规则 用 一 组 二 
进 制 编码 来 表示 。 字 符 编 码 方式 有 很 多 种 ,现在 用 得 最 广泛 的 是 美国 国家 信息 交换 标准 字 
符 码 (American Standard Code for Information Interchange,ASCII) 。 

常见 的 ASCII 码 用 7 位 二 进 制 表示 一 个 字符 ,ASCII 码 包 括 10 个 十 进 制 数字 (0 一 9)、 
52 个 英文 大 写 和 小 写字 母 (A~Z 和 a 一 z) .34 个 专用 符号 和 32 个 控制 符号 ,共计 128 个 字 
符 。 在 128 个 字符 中 有 96 个 是 可 打印 字符 。 

在 计算 机 中 ,通常 用 一 a 个 字符 。 对 于 ASCII 码 来 说 ,一 个 字 节 右边 的 7 
位 表示 不 同 的 字符 代码 ,而 最 左边 一 位 可 以 作为 奇偶 校 验 位 ,用 来 检查 错误 ,也 可 以 用 于 西 
文字 符 和 汉字 的 区 分 标识 。 

ASCI 字符 编码 表 如 表 2-5 所 示 。 由 表 中 可 见 , 数 字 和 英文 字母 都 是 按 顺 序 排 列 的 ,只 
要 知道 其 中 一 个 的 二 进 制 代码 ,不 用 查 表 就 可 以 推导 出 其 他 数字 或 字母 的 二 进 制 代 码 。 另 
外 ,如 果 将 ASCII 码 中 0 一 9 十 个 数字 的 二 进 制 代码 去 掉 最 高 3 位 011, 正 好 与 它们 的 二 进 
制 值 相 同 , 这 不 但 使 十 进 制 数 字 进 入 计算 机 后 易于 压缩 成 4 位 代码 ,而 且 也 便于 进一步 的 信 
息 处 理 。 


表 2-5 ASCII 字符 编码 表 


L141 


0 
1 
2 
3 
1 
9 
6 
7 
8 
9 


一 一 中 中 由 口 口 角 m 国 
NKXXx<cCJIWHDO 


N < 4% 所 < fc 0 WW Hm 局 
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除 标准 ASCII 字符 编码 外 ,许多 公司 还 使 用 8 位 二 进 制 编码 来 表示 更 大 的 字符 集 , 例 
如 IBM 公司 就 用 8 位 扩展 二 进 制 编 码 的 十 进 制 交换 码 (EBCDIC 码 ) 来 表示 IBM 计算 机 所 
用 到 的 字符 集 。 


2. 字符 串 的 存放 


字符 串 是 指 一 串 连续 的 字符 。 通 第 ,它们 在 存储 希 中 占用 一 片 连续 的 空间 ,每 个 字 节 存 
放 一 个 字符 代码 ,字符 串 的 所 有 元 素 ( 字 符 ) 在 物 
理 上 是 邻接 的 ,这 种 字符 串 的 存储 方法 称 为 癌 量 
法 。 例 如 ,字符 串 IF X>0 THEN READ (C ) ， 
在 字 长 为 32 位 的 存储 需 中 的 存放 格式 如 
图 2-7(a) 所 示 。 图 中 每 一 个 主 存单 元 可 存放 4 
个 字符 ,整个 字符 串 需 5 个 主 存单 元 。 在 每 个 字 
节 中 实际 存放 的 是 相应 字符 的 ASCII 码 , 如 
图 2-7(b) 所 示 。 

字符 串 的 向量 存放 法 是 最 人 简单、 最 节省 存储 
空间 的 方法 。 但 是 , 当 字 符 串 需要 进行 删除 和 插 
入 操作 时 ,在 删除 或 插入 字符 后 面 的 子 字 符 串 需 
要 全 部 重新 分 配 存储 空间 ,将 花费 较 多 的 时 间 。 为 了 克服 向量 存放 法 的 缺点 , 男 一 种 字符 串 
的 存储 方法 一 一 串 表 法 应 运 而 生 了 。 在 这 种 存储 方法 中 ,字符 串 的 每 个 字符 代码 后 有 一 个 
链接 字 ,用 以 指出 下 一 个 字符 的 存储 单元 地 址 。 串 表 法 不 要 求 串 中 的 各 个 字符 在 物理 上 相 
邻 , 原 则 上 讲 , 串 中 各 字符 可 以 安排 在 存储 器 的 任意 位 置 上 。 在 对 字符 串 进行 删除 和 插入 操 
作 时 ,只 需 修改 相应 字符 代码 后 面 的 链接 字 即 可 ,所 以 非常 方便 。 但 是 ,由 于 链接 字 占 据 了 
存储 单元 的 大 部 分 空间 ,使 得 主 存 的 有 效 利用 率 下 降 。 例 如 ,一 个 主 存单 元 有 32 位 , 仅 存放 
一 个 字符 代码 ,而 链接 字 占 用 了 24 位 ,这 时 ,存放 字符 串 信 息 的 主 存 有 效 利 用 率 只 占 25%， 
这 是 串 表 法 的 最 大 缺点 。 


2.3.2 汉字 的 表示 


汉字 处 理 技术 是 计算 机 推广 应 用 工作 中 必须 要 解决 的 问题 。 汉 字 的 字数 需 多 ,字形 复 
杂 ,读音 多 变 , 第 用 的 汉字 就 有 7000 个 左右 。 要 在 计算 机 中 表示 汉字 ,最 方便 的 方法 是 为 汉 
字 安 排 一 个 编码 ,而 且 要 使 这 些 编码 与 西 文 字符 和 其 他 字符 有 明显 的 区 别 。 
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1. 汉字 国标 码 


汉字 国标 码 也 称 为 汉字 交换 码 , 主 要 用 于 汉字 信息 处 理 系统 之 间或 者 通信 系统 之 间 交 
换 信息 使 用 。1981 年 国家 标准 总 局 公布 了 GB 2312 一 80, 即 《信息 交换 用 汉字 编码 字符 集 
基本 集 ), 人 简称 GB 码 。 该 标准 共 收 集 常 用 汉字 6763 个 ,其 中 一 级 汉字 3755 个 , 按 拼音 排 
序 。 二 级 汉字 3008 个 , 按 部 首 排序 。 另 外 还 有 各 种 图 形 符号 682 个 ,共计 7445 个 。 

GB 2312 一 80 规定 每 个 汉字 .图形 符号 都 用 两 个 字 节 表示 ,每 个 字 节 只 使 用 低 7 位 编 
码 ,因此 最 多 能 表示 出 128X128= 二 16 384 个 汉字 。 


2. 汉字 区 位 码 


区 位 码 将 汉字 编码 GB 2312 一 80 中 的 6763 个 汉字 分 为 94 个 区 ,每 个 区 中 包含 94 个 汉 
字 ( 位 ) ,区 和 位 组 成 一 个 二 维 数组 ,每 个 汉字 在 数组 中 对 应 一 个 唯一 的 区 位 码 。 汉 字 的 区 位 
码 定 长 4 位 ,前 两 位 表示 区 号 ,后 两 位 表示 位 号 ,区 号 和 位 号 用 十 进 制 数 表 示 , 区 号 从 01 到 
94, 位 号 也 从 01 到 94。 例 如 ,“ 中 ” 字 在 54 区 的 48 位 上 ,其 区 位 码 为 “54 一 48”,“ 国 ” 字 在 
25 区 的 90 位 上 ,其 区 位 码 为 “25 一 90”。 

区 位 码 表 的 布局 是 这 样 安排 的 ,第 1 一 15 区 包含 西 文字 母 、 数 字 和 图 形 符号 ,以 及 用 户 
自行 定义 的 专用 符号 (统称 非 汉 字 图 形 字 符 ) ;第 16 一 55 区 为 一 级 汉字 ;第 56 一 87 区 为 二 级 
汉字 ;87 区 以 上 为 空白 区 ,可 供 造 新 字 用 。 

注意 : 汉字 区 位 码 并 不 等 于 汉字 国标 码 , 它 们 两 者 之 间 的 关系 可 用 以 下 公式 表示 : 

国标 码 王 区 位 码 (十 六 进 制 ) 十 2020H 

即 首先 将 十 进 制 表示 的 区 位 码 转 换 成 十 六 进 制 表示 ,然后 再 加 上 2020H。 

例 2-15 已 知 汉 字 “ 春 ”的 区 位 码 为 “20 一 26”, 计 算 它 的 国标 码 。 

第 一 字 节 第 二 字 节 


区 位 码 : 20 26 十 进 制 
Y Y 

14H 1AH 十 六 进 制 
十 20H 二 20H 
国标 码 . 34H 3AH 


使 用 区 位 码 输入 汉字 时 ,每 输入 4 位 数字 可 得 到 一 个 汉字 ,没有 重 码 ,但 由 于 要 查阅 区 
位 码 表 ,所 以 较 及 烦 。 


3. 汉字 机 内 码 


汉字 可 以 通过 不 同 的 输入 码 输入 ,但 在 计算 机 内 部 其 内 码 是 唯一 的 。 因 为 汉字 处 理 系 
统 要 保证 中 西 文 的 兼容 , 当 系 统 中 同时 存在 ASCII 码 和 汉字 国标 码 时 ,将 会 产生 二 义 性 。 
例如 ,有 两 个 字 节 的 内 容 为 30H 和 21H, 它 既 可 表示 汉字 “ 啊 ” 的 国标 码 , 又 可 表示 西 文 “0” 
和 “1” 的 ASCII 码 。 为 此 ,汉字 机 内 码 应 对 国标 码 加 以 适当 人 处理 和 变换 。 
汉字 机 内 码 也 是 两 字 节 长 的 代码 , 它 是 在 相应 国标 码 的 每 个 字 节 最 高 位 上 加 1 所 得 , 即 
汉字 机 内 码 二 汉字 国标 码 十 8080H 
例如 ,上 述 “ 啊 ” 字 的 国标 码 是 3021H ,其 机 内 码 则 是 BOA1H。 
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4. 汉字 字形 码 


汉字 字形 码 是 指 确定 一 个 汉字 字形 点 阵 的 代码 ,又 称 汉 字 字 模 码 或 汉字 输出 码 。 在 一 
个 汉字 点 阵 中 , 凡 笔 画 所 到 之 处 , 记 为 1, 否则 记 为 0。 

根据 对 汉字 质量 的 不 同 要 求 ,可 有 16X16、24X24、32X32 或 48X48 的 点 阵 结构 。 汉 
字 点 阵 分 类 如 表 2-6 所 示 , 显 然 点 阵 越 大 ,输出 汉字 的 质量 越 高 ,每 个 汉字 所 占用 的 字 节 数 


表 2-6 汉字 点 阵 分 类 


简易 型 32 显示 字体 骨架 

普及 型 72 有 笔锋 ,可 分 字体 
提高 型 128 笔锋 清晰 ,字体 齐全 
精密 型 288 能 表示 复杂 字形 


汉字 字形 码 在 汉字 输出 时 经 常 使 用 ,所 以 要 把 各 个 汉字 的 字形 信息 固定 存储 起 来 ,存放 
各 个 汉字 字形 信息 的 实体 称 为 汉字 库 。 汉 字库 的 信息 量 很 大 ,一 个 16X16 点 阵 的 基本 汉字 
库 至 少 需要 256KB, 而 24X24 点 阵 的 汉字 库 至 少 需 576KB。 


5. 汉字 编码 的 发 展 


GB 2312 是 在 中 国 大 陆 及 海外 使 用 简体 中 文 的 国家 和 地 区 (如 新 加 坡 等 ) 强 制 使 用 的 唯 
一 中 文 编码 ,但 它 只 有 6000 多 个 汉字 ,已 不 能 满足 各 方面 应 用 的 需要 。 国 家 标准 总 局 在 
1990 年 颁布 了 繁体 字 的 编码 标准 GB 12345 一 90《 信 息 交 换 用 汉字 编码 字符 集 第 一 辅助 
集 ), 目 的 在 于 规范 必须 使 用 繁体 字 的 各 种 场合 ,该 标准 共 收 录 6866 个 汉字 ( 比 GB 2312 多 
103 个 字 ), 纯 繁体 的 字 大 概 有 2200 个 ,每 个 汉字 都 采用 双 字 节 编 码 。1995 年 年 底 推出 的 
GBK 编码 是 中 文 编码 扩展 国家 标准 ,该 编码 标准 羔 容 GB 2312, 共 收录 汉字 21 003 个 、 符 号 
883 个 ,并 提供 1894 个 造 字 码 位 ,人 简 .繁体 字 融 于 一 库 ,GBK 也 采用 双 字 节 编 码 。 

随 着 国际 间 交 流 与 合作 的 扩大 ,信息 处 理应 用 对 字符 集 提出 了 多 文 种 、 大 字 量 、 多 用 途 
的 要 求 。1993 年 国际 标准 化 组 织 发 布 了 ISO/ 10646 一 1《 信 息 技 术 通 用 多 八 位 编码 字符 集 
第 一 部 分 体系 结构 与 基本 多 文 种 平面 》。 我 国 根据 此 标准 制定 了 GB 13000. 1 一 93 ,该 标准 
采用 了 全 新 的 多 文 种 编码 体系 ,收录 了 中 日 、 韩 (CJK 统一 汉字 )20 902 个 ,是 编码 体系 未 
来 的 发 展 方向 。 由 于 其 新 的 编码 体系 与 现 有 多 数 操作 系统 和 外 部 设备 不 兼容 ,所 以 它 的 实 
现 仍 需 要 一 个 过 程 。 

考虑 到 GB 13000 的 完全 实现 有 待 时 日 ,以 及 GB 2312 编码 体系 的 延续 性 和 现 有 资源 
和 系统 的 有 效 利用 与 过 渡 。2000 年 年 底 ,我 国 国家 标准 总 局 颁布 了 GB 18030 大 字符 集 标 
准 , 这 个 标准 全 面 兼 容 GB 2312 ,在 字汇 上 兼容 GB 13000。 目 前 ,GB 18030 有 两 个 版 本 : 
GB 18030 一 2000 和 GB 18030 一 2005。GB 18030 一 2000 规定 了 常用 非 汉 字符 号 和 27 533 
个 汉字 (包括 部 首 、 部 件 等 ) 的 编码 。GB 18030 一 2005 是 以 汉字 为 主 并 包含 多 种 我 国 少数 民 
族 文字 (如 藏 、 蒙古 、 傣 、 醚 、 衣 鲜 、 维 召 尔 文 等 ) 的 超大 型 中 文 编码 字符 集 , 其 中 收录 汉字 
70 244 个 (在 GB 18030 一 2000 的 基础 上 增加 了 42 711 个 ) 。GB 18030 采用 单字 节 、 双 字 
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节 、4 字 节 混合 编码 ,编码 空间 超过 150 万 个 。 

从 ASCII、.GB 2312、GBK 到 GB 18030 ,这 些 编码 方法 是 向 上 兼容 的 , 即 同一 个 字符 在 
这 些 方 案 中 总 是 有 相同 的 编码 ,后 面 的 标准 支持 更 多 的 字符 。 为 了 保证 中 西 文 兼容 ,确定 中 
文 编码 的 方法 是 :高 字 节 的 最 高 位 为 1 ,不 用 管 低 字 节 最 高 位 是 什么 。 


2.3.3 统一 代码 


统一 代码 (Unicode) 又 称 万 国 码 、 单 一 码 , 它 是 由 多 语言 软件 制造 商 组 成 的 统一 码 联盟 
制定 的 可 以 容纳 世界 上 所 有 文字 和 符号 的 字符 编码 方案 。Unicode 随 看 通用 字符 集 的 标准 
而 发 展 , 至 今 仍 在 不 断 增加 和 修改 ,Unicode 1.0 于 1991 年 10 月 发 布 ,截至 目前 为 止 已 发 布 
了 24 个 版 本 ,每 个 新 版 本 部 会 加 入 更 多 新 的 字符 ,目前 最 新 的 版 本 为 2018 年 6 月 发 布 的 
Unicode 11. 0。 

Unicode 可 分 为 编码 方式 和 实现 方式 两 个 层次 。 


1. 编码 方式 


Unicode 的 编码 方式 与 国际 标准 ISO/IEC 10646 的 通用 字符 集 (Universal Character 
Set,UCS) 概 念 相对 应 ,两 者 的 码 表 兼容 ,并 共同 调整 任何 未 来 的 扩展 。 

Unicode 的 基本 方法 是 用 一 个 16 位 的 二 进 制 数 (2 字 节 ) 来 表示 Unicode 中 的 每 个 符 
号 ,这 意味 着 允许 表示 65 536 个 不 同 的 字符 或 符号 。 这 种 符号 集 被 称 为 基本 多 语言 平面 
(BMP) ,基本 多 语言 平面 的 字符 编码 为 U 十 hhhh, 其 中 每 个 h 代表 一 个 十 六 进 制 数字 , 与 
UCS-2 编码 完全 相同 。 

UCS-4 是 一 个 更 大 的 尚未 填充 完全 的 31 位 字符 集 , 加 上 人 恒 为 0 的 首位 , 共 需 占据 
32 位 , 即 4 字 节 。 理 论 上 最 多 能 表示 22 个 字符 ,完全 可 以 涵盖 一 切 语 言 所 用 的 符号 。 目 
前 ,Unicode 计划 使 用 了 17 个 平面 (1 个 基本 语言 平面 和 16 个 辅助 平面 ), 一 共有 17 义 
65 536 王 1 114 112 个 码 位 。 

图 2-8 给 出 了 在 微机 中 用 的 扩展 ASCII 码 、Unicode UCS-2 和 UCS-4 方法 表示 一 个 字 
符 之 间 的 差异 。 例 如 ,字符 A 用 UCS-2 表示 为 “U 十 0041”, 而 其 对 应 的 UCS-4 的 后 两 个 字 
节 与 UCS-2 一 致 ,前 两 个 字 节 则 所 有 位 均 为 0。 
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2. 实现 方式 


Unicode 的 实现 方式 不 同 于 编码 方式 。 一 个 字符 的 Unicode 编码 是 确定 的 ,但 是 在 实 
际 传输 过 程 中 ,由 于 不 同系 统 平台 的 设计 不 一 定 一 致 ,以 及 出 于 节省 空间 的 考虑 , Unicode 
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编码 的 实现 方式 会 有 所 不 同 。Unicode 的 实现 方式 称 为 Unicode 转换 格式 (Unicode 
Translation Format，UTF) ,目前 存在 的 UTF 格式 有 UTF-7、UTF-7.5、UTF-8、UTF-16 
和 UTF-32。 

例如 ,UTF-8 编码 是 一 种 变 长 编码 ,用 1 一 6 个 字 节 编码 Unicode 字符 。 它 将 基本 7 位 
ASCII 字符 仍 用 7 位 编码 表示 ,占用 1 个 字 节 (首位 补 0)。 而 遇 到 与 其 他 Unicode 字符 混合 
的 情况 ,将 按 一 定 算法 转换 ,UCS-2 转换 成 UTF-8 很 可 能 需要 3 个 字 节 , UCS-4 转换 成 
UTF-8 很 可 能 需要 6 个 字 节 。 这 样 以 7 位 ASCII 字符 为 主 的 西 文 文档 大 大 节省 了 编码 
长 度 。 

UTF-16 比 起 UTF-8, 好 处 在 于 大 部 分 字符 都 以 固定 长 度 的 字 节 (2 字 市 ) 存 储 , 但 
UTF-16 却 无 法 兼容 ASCII 编码 。 


2.4 十 进 制 数 和 数 串 的 表示 


十 进 制 是 人 们 最 常用 的 数据 表示 方法 ,一 些 通用 性 较 强 的 计算 机 上 设 有 十 进 制 数 据 的 
表示 ,可 以 直接 对 十 进 制 数 进行 运算 和 处 理 。 


2.4.1 十 进 制 数 的 编码 


二 进 制 是 计算 机 最 适合 的 数据 表示 方法 ,把 十 进 制 数 的 各 位 数字 变 成 一 组 对 应 的 二 进 
制 代码 ,用 4 位 二 进 制 数 来 表示 1 位 十 进 制 数 , 称 为 二 进 制 编码 的 十 进 制 数 (Binary Code 
Decimal) , 即 BCD 码 。4 位 二 进 制 数 可 以 组 合 出 16 种 代码 ,能 表示 16 种 不 同 的 状态 ,只 需 
要 使 用 其 中 的 10 种 状态 ,就 可 以 表示 十 进 制 数 的 0 一 9 十 个 数码 ,而 其 他 的 6 种 状态 为 元 余 
状态 。 由 于 可 以 取 任 意 的 10 种 代码 来 表示 10 个 数码 ,所 以 就 可 能 产生 多 种 BCD 编码 。 
BCD 编码 既 具 有 二 进 制 数 的 形式 ,又 保持 了 十 进 制 数 的 特点 ,可 以 作为 人 机 联系 的 一 种 中 
间 表 示 ,也 可 以 用 它 直 接 进 行 运算 。 表 2-7 列 出 了 几 种 常见 的 BCD 码 。 


表 2-7 常见 的 BCD 编码 


0000 
0001 
0011 
0010 
0110 
1110 
1010 
1011 
1001 
1000 


‘OO 00 WW ND ~ OO 


1. 8421 码 


8421 码 又 称 为 自然 (Nature)BCD 码 , 简 称 NBCD 码 ,4 位 二进制 代码 的 位 权 从 高 到 低 
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分 别 为 8、4、2、1, 这 种 编码 的 主要 特点 如 下 : 

OO 它 是 一 种 有 权 码 , 设 其 各 位 的 值 为 5;6;b15, 则 它 所 表示 的 十 进 制 数 D = 86; 十 40， 
十 261 十 166。 

多 简单 直观 ,每 个 代码 与 它 所 代表 的 十 进 制 数 之 间 符 合 二 进 制 数 和 十 进 制 数 相互 转换 
的 规则 。 

@) 不 允许 出 现 1010 一 1111, 这 6 个 代码 在 8421 码 中 是 非法 码 。 

注意 : 尽管 在 8421 码 中 0 一 9 十 个 数码 的 表示 形式 与 用 二 进 制 表示 的 形式 一 样 , 但 这 
是 两 个 完全 不 同 的 概念 ,不 能 混 消 。 例 如 ,一 个 两 位 的 十 进 制 数 39, 它 可 以 表示 为 (0011 
1001)soi 与 100111B, 这 两 者 是 完全 不 同 的 。 


2. 2421 码 


2421 人 码 其 编码 各 位 的 位 权 从 高 到 低 分 别 为 2.4、2、1, 它 的 主要 特点 如 下 : 

Q 它 也 是 一 种 有 权 码 ,所 表示 的 十 进 制 数 D==26; 十 46;s 十 2051 十 16o。 

@ 它 又 是 一 种 对 9 的 自 补 码 , 即 某 数 的 2421 码 , 只 要 自身 按 位 取 反 ,就 能 得 到 该 数 对 
9 补 数 的 2421 码 。 例 如 ,3 的 2421 码 是 0011,3 对 9 的 补 数 是 6, 而 6 的 2421 码 是 1100, 即 
将 3 的 2421 码 自身 按 位 取 反 可 得 到 6 的 2421 码 。 在 十 进 制 运算 中 ,采用 自 补 码 , 可 以 使 运 
算 天 线路 催化 。 

@ 不 允许 出 现 0101 一 1010 ,这 6 个 代码 在 2421 码 中 是 非法 码 。 

对 于 有 权 码 来 说 , 当 规定 各 位 的 权 不 同时 ,可 以 有 多 种 不 同 的 编码 方案 ,例如 还 有 4221 
码 、4421 码 .5421 码 和 84-2-1 码 等 多 种 编码 方案 。 


3. 余 3 码 


余 3 码 是 一 种 无 权 码 ,从 表 2-7 中 可 以 看 出 , 余 3 码 是 在 8421 码 的 基础 上 加 0011 形成 
的 , 因 每 个 数 都 余 3, 故 称 余 3 码 , 其 主要 特点 如 下 : 

QO 它 是 一 种 无 权 码 , 在 这 种 编码 中 各 位 的 “1? 不 表示 一 个 固定 的 十 进 制 数值 ,因而 不 直 
观 , 且 容易 搞 错 。 

@ 它 也 是 一 种 对 9 的 自 补 码 。 

@ 不 允许 出 现 0000 一 0010 和 1101 一 1111, 这 6 个 代码 在 余 3 码 中 是 非法 码 。 


4. 格雷 码 (Gray 码 ) 


十 进 制 Gray 码 的 方案 有 很 多 种 , 表 2-7 中 列 出 的 只 是 其 中 的 一 种 。Gray 码 可 以 避免 
在 计数 时 发 生 中 间 错 误 , 所 以 也 被 称 为 可 菲 性 编码 。 其 主要 特点 如 下 : 

J 它 也 是 一 种 无 权 码 。 

G@ 从 一 种 代码 变 到 相 邻 的 下 一 种 代码 时 ,只 有 一 个 二 进 制 位 的 状态 在 发 生变 化 。 

(3 具有 循环 特性 , 即 首 尾 两 个 数 的 Gray i 个 二 进 制 位 不 同 ,因此 Gray 码 又 
称 为 循环 码 。 

由 十进制 Gray 码 也 有 6 个 代码 为 非法 码 , 视 具体 方案 而 定 。 


2.4.2 十 进 制 数 串 
十 进 制 数 在 计算 机 中 是 以 数 串 的 形式 存储 和 处 理 的 。 十 进 制 数 串 的 长 度 是 可 变 的 ,不 
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受 定 点 数 和 浮 点 数 统一 格式 的 约束 。 十 进 制 数 在 计算 机 内 有 两 种 表示 形式 : 非 压缩 的 十 进 
制 数 和 压缩 的 十 进 制 数 。 


1. 非 压 缩 的 十 进 制 数 串 


非 压 缩 的 十 进 制 数 串 实际 上 就 是 前 述 的 字符 串 , 即 一 个 字 节 存放 一 个 十 进 制 数 或 符号 
的 ASCII 码 。 在 主 存 中 ,这 样 的 十 进 制 数 串 占 用 连续 的 多 个 字 节 。 为 了 指明 一 个 数 串 , 需 
要 给 出 该 数 串 在 主 存 中 的 起 始 地 址 和 串 长 。 

非 压 缩 的 十 进 制 数 串 又 根据 符号 所 处 的 位 置 ,分 成 前 分 隔 式 数字 串 和 后 艇 入 式 数 字 串 
两 种 格式 。 在 前 分 隔 式 数字 串 中 ,符号 位 占用 单独 一 个 字 节 , 放 在 数值 位 之 前 , 正 号 对 应 的 
ASCII 码 为 2BH , 负 号 对 应 的 ASCII 码 为 2DH。 在 后 嵌入 式 数 字 串 中 ,符号 位 不 单独 占用 
一 个 字 节 ,而 是 蕨 入 到 最 低 一 位 数字 里 。 奋 数 串 为 正 , 则 最 低 一 位 数字 0 一 9 的 ASCII 码 不 
变 (30H 一 39H); 若 数 串 为 负 , 把 负 号 变 为 40H, 并 将 其 与 最 低 数 值 位 相 加 ,此 时 数字 
0 一 9 的 ASCII 码 变 为 70H 一 79H。 

非 压 缩 的 十 进 制 数 串 主要 应 用 于 非 数 值 处 理 ,而 对 十 进 制 数 的 算术 运算 是 很 不 方便 的 。 
因为 每 一 字 节 中 只 有 低 4 位 表示 数值 ,而 高 4 位 在 算术 运算 时 不 具有 数值 的 意义 。 


2. 压缩 的 十 进 制 数 串 


压缩 的 十 进 制 数 串 ,一 个 字 节 可 存放 两 位 BCD 码 表示 的 十 进 制 数 , 既 节 省 了 存储 空间 ， 
又 便于 直接 进行 十 进 制 算术 运算 ,是 广泛 采用 的 表示 方式 。 

在 主 存 中 ,一 个 压缩 的 十 进 制 数 串 占用 连续 的 多 个 字 节 ,每 位 数字 仅 占 半 个 字 节 ,其 值 
稼 用 8421 码 表示 。 符 号 位 也 占 半 个 字 节 ,并 存放 在 最 低 数 值 位 之 后 ,通常 用 CH 表示 正 号 ， 
DH 表示 负 号 。 在 这 种 表示 中 ,规定 数字 的 个 数 加 符号 位 之 和 必须 为 偶数 ; 当 和 为 奇数 时 ， 
应 在 最 高 数值 位 之 前 补 0H( 即 第 一 个 字 节 的 高 半 字 节 为 0000) 。 

例 2-16 十 123 表示 为 ; 


0001 : 0010 0011 : 1100 


一 2648 表示 为 : 


0000 ; 0010 0110 : 0100 1000 : 1101 


要 指明 一 个 压缩 的 十 进 制 数 串 ,也 必须 给 出 它 在 主 存 中 的 首 地 址 和 串 长 。 
2.5 不 同类 型 的 数据 表示 举例 
前 面 已 经 讨论 了 许多 种 不 同类 型 的 数据 表示 ,这 里 将 以 实际 广泛 应 用 的 C 语言 中 的 数 
据 类 型 和 现代 微型 计算 机 中 的 数据 表示 作为 实例 进行 介绍 。 
2.5.1 CC 语言 中 的 数据 表示 


C 语言 的 基本 数据 类 型 有 整 型 数据 、 实 型 数据 .字符 型 数据 等 ,下 面 仅 讨论 整数 类 型 和 
实数 类 型 的 表示 。 
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1. 整数 类 型 


C 语言 中 文 持 多 种 整数 类 型 ,二进制 整数 分 为 无 符号 整数 和 市 符号 整数 。 

(1) 无 符号 整数 

无 符号 整数 对 应 unsigned short、 unsigned int、unsigned long 等 类 型 。 以 PC 为 例 ， 
unsigned short( 无 符号 短 整 型 ) 和 unsigned int( 无 符号 基本 整 型 ) 字 长 为 16 位 , 数 的 范围 是 
0 一 65 535;unsigned long( 无 符号 长 整 型 ) 字 长 为 32 位 , 数 的 范围 是 0 一 4 294 967 295。 

(2) 市 符号 整数 

带 符 号 整数 对 应 short、int、long 等 类 型 。 以 PC 为 例 ,short( 短 整 型 ) 和 int( 基 本 整 型 ) 
字 长 为 16 位 , 数 的 范围 为 一 32 768 一 32 767; long( 长 整 型 ) 字 长 为 32 位 , 数 的 范围 为 
一 2 147 483 648 一 2 147 483 647 。 


2. 实数 ( 浮 点 数 ) 类 型 


C 语言 中 有 float 和 double 两 种 不 同 浮 点 数 类 型 ,分 别 对 应 IEEE 754 单 精 度 浮 点 数 格 
式 (32 位 ) 和 双 精 度 浮 点 数 格式 (64 位 ) ,前 者 数 的 范围 是 一 3.4X10” 一 3.4X10” ,后 者 数 的 
范围 是 一 1.79X10”~1.79X10 ,相应 的 十 进 制 有 效 数 字 分 别 为 6 位 和 16 位 。 

浮 点 数 均 为 市 符号 浮 点 数 , 没 有 无 符号 浮 点 数 。 


3. 不 同 数据 类 型 之 间 的 转换 


数据 类 型 的 转换 有 以 下 3 种 基本 形式 : 

J 同一 类 型 但 长 度 不 同 的 数据 间 的 转换 。 

@ 定点 方式 与 浮 点 方式 间 的 转换 。 

G) 整 型 数 中 的 带 符 号 格式 与 无 符号 格式 间 的 转换 。 

双 目 运算 符 两 侧 的 操作 数 的 类 型 必须 一 致 ,所 得 计算 结果 的 类 型 与 操作 数 的 类 型 一 致 。 
如 果 一 个 运算 符 两 边 的 操作 数 类 型 不 同 , 则 系统 将 目 动 按照 转换 规律 先 对 操作 数 进行 类 型 
转换 骨 进 行 运算 ,通常 数据 之 间 转 换 遵循 的 原则 是 “类 型 提升 ”, 即 较 低 类 型 转换 为 较 高 类 
型 。 例 如 ,float 型 和 double 型 数据 参加 运算 ,虽然 它们 同 为 实 型 ,但 两 者 的 精度 不 同 , 需 要 
先 将 float 型 转换 成 double 型 再 进行 运算 ,结果 为 double 型 。 再 如 ,一 表达 式 中 包含 int、 
long 和 double 类 型 的 变量 和 数据 , 则 表达 式 最 后 的 运算 结果 是 double 型 ,3 种 类 型 数据 转 
换 规 律 为 int>long 习 double。 所 有 这 些 转 换 剖 是 由 系统 自动 进行 的 ,这 种 转换 通常 称 为 隐 
式 转 换 。 

类 型 提升 (升格 ) 时 ,其 值 保 持 不 变 。 例 如 ,在 将 16 位 数 与 32 位 数 相 加 之 前 ,必须 将 16 
位 数 转换 成 32 位 数 形式 ,这 被 称 为 “符号 扩展 ”, 即 用 符号 位 来 填充 所 有 附加 位 。 

当 较 高 类 型 的 数据 转换 成 较 低 类 型 的 数据 时 , 称 为 降格 ,降格 时 就 可 能 失去 一 部 分 
信息 。 
除了 隐 式 转换 外 ,还 有 一 种 转换 称 为 显 式 转换 ,这 是 一 种 强制 转换 类 型 机 制 。 显 式 转换 
实际 上 是 一 种 单 目 运 算 ,其 一 般 形 式 为 : 

(数据 类 型 名 ) 表 达 式 
显 式 转换 把 后 面 的 表达 式 运 算 结果 的 类 型 强制 转换 为 要 求 的 类 型 ,而 不 管 类 型 的 高 低 。 
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要 转换 的 表达 式 用 括号 插 起 来 ,例如 , (int) (zx 十 y) 与 (int)zx 十 y 是 不 同 的 ,后 者 相当 于 
(int) (zx) 十 y, 也 就 是 说 ,只 将 xz 转换 成 整 型 ,然后 与 y 相 加 。 


2.5.2 现代 微型 计算 机 系统 中 的 数据 表示 


现代 的 微型 计算 机 系统 大 多 采用 Intel 系列 的 微 处 理 右 ,近年 来 ,Intel 的 微 处 理 咒 有 了 
极 大 的 发 展 , 从 80386 到 80486、Pentium、 Pentium MMX 、Pentium Pro、Pentium 工 、 
Pentium 了 由 直至 Pentium 4 ,形成 了 IA(CIntel Architecture)-32 结构 。 而 最 新 的 Itanium 处 
理 融 是 目前 Intel 公司 推出 的 最 高 端 处 理 帮 ,是 第 一 球 真 正 64 位 产品 (IA-64)。 下 面 以 IA- 
32 结构 为 例 , 介 绍 现代 微机 系统 的 数据 表示 。 

IA-32 结构 的 基本 数据 类 型 是 字 节 、 字 、 双 字 (DWORD)、 四 字 (QWORD) 和 双 四 字 
(DQWORD) ,如 图 2-9 所 示 。 


7 0 
| 
N 


高 字 广 ” 低 字 市 


高 双 字 低 双 字 ”| 四 字 
N+4 N 
127 64 63 0 


高 四 字 低 四 字 双 四 字 


N+8 N 
2-9 ”IA-32 结构 的 基本 数据 类 型 


注意 : 在 IA-32 结构 的 所 有 机 器 中 ,一 个 字 都 等 于 16 位 (两 个 字 节 )。 双 字 是 4 字 节 
(32 位 ) ,四 字 是 8 字 节 (64 位 ), 双 四 字 是 16 字 节 (128 位 )。 

四 字 是 在 微 处 理 需 80486 中 引入 IA-32 结构 的 , 双 四 字 是 在 具有 SSE 扩展 的 微 处 理 大 
Pentium 轩 中 引入 的 。 


1. 无 符号 整数 


无 符号 整数 是 包含 字 节 、 字 、 双 字 和 四 字 的 无 符号 的 二 进 制 数 。 无 符号 整数 的 范围 ,对 
于 字 节 ,是 0 一 255; 对 于 字 ,是 0 一 65 535; 对 于 双 字 ,是 0 一 2” 一 1; 对 于 四 字 ,是 0 一 2 一 1。 


2. 市 符号 整数 


种 符号 整数 是 包含 字 节 、 字 、 双 字 和 四 字 的 融 符 号 的 二 进 制定 点 整数 。 所 有 和 融 符 号 整数 
的 数据 类 型 都 以 补 码 形式 表示 ,和 从 号 位 是 最 高 位 (MSB)。 正 数 的 符号 位 为 “0”, 人 负数 的 符号 
位 为 “1”。 吝 符号 整数 的 范围 ,对 于 字 节 ,是 一 128 一 十 127; 对 于 字 ,是 一 32 768 一 十 32 767; 
对 于 双 字 ,是 一 222 一 十 22 一 1; 对 于 四 字 , 是 一 2 一 十 2 一 1。 
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3. 浮 点 数 

IA-32 结构 定义 和 操作 3 种 浮 点 数据 类 型 : 单 精 度 浮 点 数 ( 短 浮 点 数 )、 双 精度 浮 点 数 
(长 浮 点 数 ) 和 扩展 精度 浮 点 数 ( 临 时 浮 点 数 )。 

这 些 数据 类 型 的 格式 与 IEEE 754 标准 所 规定 的 格式 直接 对 应 ,在 此 不 再 重复 。 

4. 指针 数据 


指针 是 主 存单 元 的 地 址 ,IA-32 结构 定义 了 两 种 类 型 的 指针 : 近 (Near) 指 针 (32 位 ) 和 
远 (Far) 指 针 (48 位 ) ,如 图 2-10 所 示 。 近 指针 是 段 内 的 32 位 偏 移 量 ( 也 称 为 有 效 地 址 ) , 段 
内 寻 址 时 用 。 远 指针 是 一 个 48 位 的 逻辑 地 址 ,包含 16 位 段 选 择 符 和 32 位 的 偏 移 量 , 用 于 
路 段 访问 。 
近 指针 


偏 移 量 
31 0 
远 指 针 
段 选择 符 偏 移 量 


47 32 31 
图 2-10 ”指针 数据 类 型 


De 


S。 串 数据 


串 是 位 . 字 节 、 字 或 双 字 的 连续 序列 。 串 数据 包括 位 串 和 字 节 串 。 位 串 是 指 连续 的 位 ， 
它 能 从 任 一 字 节 的 任 一 位 置 开 始 , 位 串 长 度 可 达 2 到 一 1 位 。 字 节 串 包含 连续 的 字 节 、 字 
双 字 ,长 度 为 0 一 23 一 1 字 节 (4GB) 。 


吕 


6. BCD 数 


IA-32 结构 中 所 指 的 BCD 码 实际 上 是 指 8421 码 。BCD 数 又 分 成 未 拼装 的 BCD 
(UBCD) 数 和 拼装 的 BCD 数 两 种 。UBCD 数 的 一 个 字 节 仅 包 含 一 位 十 进 制 数 ,在 3 一 0 位 
上 ;而 经 过 拼装 的 BCD 数 ,一 个 字 节 包含 两 位 十 进 制 数 ,其 低位 在 3 一 0 位 上 ,高 位 在 7 一 4 
位 上 。 


2.6 数据 校 验 码 


数据 在 存 取 和 传送 的 过 程 中 可 能 会 发 生 错 误 ,产生 错误 的 原因 可 能 有 很 多 种 ,例如 ， 
设备 的 临界 工作 状态 .外 界 高 频 干 扰 、 收 发 设备 中 的 间歇 性 故 隐 以 及 电源 偶然 的 瞬 变 现 
象 等 。 为 了 减少 和 避免 错误 ,除了 需要 提高 硬件 本 身 的 可 靠 性 外 ,还 要 在 数据 编码 上 找 
出 路 。 

数据 校 验 码 是 指 那些 能 够 发 现 错误 或 者 能 够 月 动 纠正 错误 的 数据 编码 ,又 称 为 " 检 错 纠 
错 编码 ”。 任 何 一 种 编码 都 由 许多 码 字 构成 ,任意 两 个 码 字 之 间 最 少 变 化 的 二 进 制 位 数 称 为 
数据 校 验 码 的 码 距 。 例 如 ,用 4 位 二 进 制 表 示 16 种 状态 , 则 有 16 个 不 同 的 码 字 ,此 时 码 距 
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为 1, 即 两 个 码 字 之 间 最 少 仅 有 一 个 二 进 制 位 不 同 ( 如 0000 一 0001)。 这 种 编码 没有 检 错 能 
力 , 因 为 当 某 一 个 合法 码 字 中 有 一 位 或 几 位 出 错 ,就 变 成 另 一 个 合法 码 字 了 。 

具有 检 、 纠 错 能 力 的 数据 校 验 码 的 实现 原理 是 : 在 编码 中 ,除去 合法 的 码 字 外 ,再 加 
进 一 些 非法 的 码 字 , 当 某 个 合法 码 字 出 现 错误 时 就 变 成 非法 码 字 。 合 理 地 安排 非法 码 字 
的 数量 和 编码 规则 ,就 能 达到 纠 错 的 目的 。 例 如 , 若 用 4 位 二 进 制 表 示 8 个 状态 ,其 中 只 
有 8 个 码 字 是 合法 码 字 ,而 另 8 个 码 字 为 非法 码 字 ,此 时 码 距 为 2。 对 于 码 距 三 2 的 数据 
校 验 码 ,开始 具有 检 错 的 能 力 。 码 距 越 大 , 检 、 纠 错 能 力 就 越 强 ,而 且 检 错 能 力 总 是 大 于 
或 等 于 纠 错 能 力 。 


2.6.1 和 奇偶 校 验 码 
1. 奇偶 校 验 概 念 


奇偶 校 验 码 是 一 种 最 简单 的 数据 校 验 码 , 它 的 码 距 等 于 2, 可 以 检测 出 一 位 错误 
(或 奇数 位 错误 ) ,但 不 能 确定 出 错 的 位 置 ,也 不 能 检测 出 偶数 位 错误 。 事 实 上 一 位 出 
错 的 概率 比 多 位 同时 出 错 的 概率 要 高 得 多 ,所 以 虽然 奇偶 校 验 码 的 检 错 能 力 很 低 , 但 
还 是 一 种 应 用 最 广泛 的 校 验方 法 , 帝 用 于 存储 融 谈 、 写 检查 或 ASCI 字符 传送 过 程 中 
的 检查 。 

奇偶 校 验 实现 方法 是 : 由 奋 干 位 有 效 信 息 ( 如 一 个 字 节 ) ,再 加 上 一 个 二 进 制 位 ( 校 验 
位 ) 组 成 校 验 码 ,如 图 2-11 所 示 。 校 验 位 的 取 值 (0 或 奇偶 校 验 位 
1) 将 使 整个 校 验 码 中 1 的 个 数 为 奇数 或 偶数 ,所 以 有 -一 

UE 

如 下 两 种 可 供 选 择 的 校 验 规律 : [人 人 

奇 校 验 一 一 整个 校 验 码 (有 效 信息 位 和 校 验 奇偶 校 验 码 
位 ) 中 1 的 个 数 为 奇数 。 2 11 奇偶 校 验 码 

凶 偶 校 验 一 一 整个 校 验 码 中 1 的 个 数 为 偶数 。 


2. 简单 奇偶 校 验 


简单 奇偶 校 验 仅 实现 横向 的 奇偶 校 验 , 表 2-8 给 出 了 几 个 字 节 的 奇偶 校 验 码 的 编码 
结果 。 


表 2-8 奇偶 校 验 码 实例 


有 效 信息 (8 位 ) 奇 校 验 码 (9 位 ) 偶 校 验 码 (9 位 ) 


00000000 100000000 000000000 
01010100 001010100 101010100 
01111111 001111111 101111111 
11111111 111111111 011111111 


在 表 2-8 所 示 的 奇 校 验 码 或 偶 校 验 码 中 ,最 高 一 位 为 校 验 位 ,其 余 8 位 为 信息 位 。 
在 实际 应 用 中 ,多 采用 奇 校 验 ,因为 奇 校 验 中 不 存在 全 0 代码 ,在 茶 些 场合 下 更 便于 
判别 。 


数据 的 机 器 层次 表示 


奇偶 校 验 码 的 编码 和 校 验 是 由 专门 的 电路 实现 的 , 篆 见 的 有 并 行 奇 偶 统 计 电 路 ,如 
图 2-12 所 示 。 这 是 一 个 由 知 干 个 异 或 门 组 成 的 塔 形 结构 ,同时 给 出 了" 偶 形成 交 奇 形成 光 偶 
校 验 出 错 ” 和 “ 奇 校 验 出 错 ” 等 信号 。 


J i , 偶 校 验 奇 校 验 
奇 形 成 ” 侦 形 成 ”出错 中 人 
, 4 ?| 
DDe Di Da D; D, DI Do Di 


图 2-12 奇偶 校 验 位 的 形成 及 校 验 电路 


偶 形 成 = D:D 中 D; BD, BD; WWD, DDIOD, 
奇 形 成 = D1; 中 D6 中 D; DBD; WD: BDOD, 
偶 校 验 出 错 王 必 由 D 由 Di 由 Di 由 Di 中 D: 由 忆 中 Di 中 Po 
奇 校 验 出 错 一 帮 由 D 由 Di 由 Di 由 Di 由 D: 由 D 由 Di 中 Du 
下 面 以 奇 校 验 为 例 , 说 明 对 主 存 信 息 进 行 奇 偶 检 验 的 全 过 程 。 
(1) 校 验 位 形成 
当 要 把 一 个 字 节 的 代码 D; 一 Du, 写 入 主 存 时 ,就 同时 将 它们 送 往 奇偶 校 验 逻 辑 电路 ,该 
电路 产生 的 “ 奇 形 成 ”信号 就 是 校 验 位 。 它 将 与 8 位 代码 一 起 作为 奇 校 验 码 写 入 主 存 。 
若 D; 一 De 中 有 偶数 个 1, 则 “ 奇 形 成 ”= 二 1; 若 D1 一 D。 中 有 奇数 个 1, 则 “ 奇 形 成 ”==0。 
(2) 校 验 检测 
读 出 时 ,将 读 出 的 9 位 代码 (8 位 信息 位 和 1 位 校 验 位 ) 同 时 送 入 奇偶 校 验 电路 检测 。 
若 读 出 代码 无 错 , 则 “ 奇 校 验 出 错 ”==0; 若 读 出 代码 中 的 某 一 位 上 出 现 错误 , 则 “ 奇 校 验 出 
错 ”==1, 从 而 指示 这 个 9 位 代码 中 一 定 有 某 一 位 出 现 了 错误 ,但 具体 的 错误 位 置 是 不 能 
确定 的 。 


3. 交叉 奇偶 校 验 


计算 机 在 进行 大 量 字 节 ( 数 据 块 ) 传 送 时 ,不 仅 每 一 个 字 节 有 一 个 奇偶 校 验 位 做 横向 校 
验 , 而 且 全 部 字 节 的 同一 位 也 设置 一 个 奇偶 校 验 位 做 纵 癌 校 验 ,这 种 模 癌 、 纵 癌 同 时 校 验 的 
方法 称 为 交叉 校 验 。 

例如 ,4 个 字 节 组 成 一 个 信息 块 , 纵 、 横 向 均 约定 为 偶 校 验 , 各 校 验 位 取 值 如 下 : 
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A A。 A; A，A; A， A A。 横向 校 验 位 
第 一 字 节 1 1 0 0 1 0 1 1 —> 1 
第 二 字 节 0 1 0 1 1 1 0 0 —> 0 
第 三 字 节 1 0 0 1 1 0 1 0 > 0 
第 四 字 节 1 0 0 1 0 1 0 1 > 0 
yy 
纵 回 校 验 位 1 0 0 1 1 0 0 0 


交叉 校 验 可 以 发 现 两 位 同时 出 错 的 情况 ,假设 第 二 个 字 节 的 As 、A, 两 位 均 出 错 , 第 二 个 
字 节 的 横 问 校 验 位 无 法 检 出 错误 ,但 是 第 As 、A, 位 所 在 列 的 纵 回 校 验 位 会 显示 出 错 , 这 与 前 
述 的 简单 奇偶 校 验 相 比 要 保险 多 了 。 


2.6.2 汉 明 校 验 码 


汉 明 码 是 Richard Hamming 于 1950 年 提出 的 ,目前 仍 是 广泛 采用 的 一 种 有 效 的 校 验 
码 , 主 存 的 ECC(Error Correcting Code) 采 用 的 就 是 与 此 类 似 的 校 验 码 。 汉 明码 实际 上 是 
一 种 多 重 奇偶 校 验 ,其 实现 原理 是 : 在 有 效 信 息 位 中 加 入 几 个 校 验 位 形成 汉 明 码 ,使 码 距 比 
较 均 勺 地 拉 大 ,并 把 汉 明 码 的 每 一 个 二 进 制 位 分 配 到 几 个 奇偶 校 验 组 中 。 当 某 一 位 出 错 后 ， 
就 会 引起 有 关 的 几 个 校 验 位 的 值 发 生变 化 ,这 不 但 可 以 发 现 错误 ,还 能 指出 错误 的 位 置 ,为 
日 动 纠 错 提供 了 依据 。 

下 面 仅 介绍 能 检测 和 自动 校正 一 位 错 并 能 发 现 两 位 错 的 汉 明 码 的 编码 原理 。 此 时 , 校 
验 位 的 位 数 K 和 信息 位 的 位 数 N 应 满足 : 2*-! 三 N 十 K 十 1。 按 该 不 等 式 , 信 息 位 N 值 和 
校 验 位 K 值 的 对 应 关系 如 表 2-9 所 示 。 


表 2-9 信息 位 NN 值 与 校 验 位 K 值 的 对 应 关系 


7 


hd 4 26~56 
4 一 10 9 W119 
ll~29 6 


若 汉 明码 的 最 高 位 号 为 加 ,最 低位 号 为 1, 即 有 昌 , 态 ,1… 昌 ;Hi , 则 此 汉 明 码 的 编码 规 
则 通常 为 : 

@ 校 验 位 和 信息 位 之 和 为 m, 每 个 校 验 位 P; 在 汉 明 码 中 被 分 到 位 号 2 一 :的 位 置 上 ,其 
余 各 位 为 信息 位 。 

区 汉 明 码 每 一 位 瓦 ;由 多 个 校 验 位 校 验 , 其 关系 是 被 校 验 的 每 一 位 位 号 等 于 校 验 它 的 
各 校 验 位 的 位 号 之 和 , 即 汉 明码 的 位 号 实质 上 是 参与 校 验 的 各 校 验 位 权 值 之 和 。 这 样 安排 
的 目的 ,是 希望 校 验 的 结果 能 正确 地 反映 出 错位 的 位 号 。 

@ 在 增 大 码 距 时 ,应 使 所 有 编码 的 码 距 尽量 均匀 地 增 大 ,以 保证 对 所 有 代码 的 检测 能 
力 平 衡 的 提高 。 

下 面 按 以 上 原则 介绍 对 一 个 字 节 信息 进行 汉 明 码 编码 和 校 验 的 过 程 。 

(1) 编码 

一 个 字 节 由 8 位 二 进 制 位 组 成 ,此 时 N= 二 8, 从 表 2-9 中 查 出 KK 二 5, 故 汉 明 码 的 总 位 数 
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为 13 位 ,可 表示 为 : 
His Hi,** H;H, 
5 个 校 验 位 P; ~ Pi 对 应 的 汉 明 码 位 号 应 分 别 为 His、 晶 ;、Hs、 晶 ;、Hi, 除 Ps; 外 ,其 余 
4 位 都 满足 P; 的 位 号 等 于 2” 的 关系 ,而 P; 只 能 放 在 五: 上 ,因为 它 已 经 是 汉 明 码 的 最 高 位 
了 。 因 此 ,有 如 下 排列 关系 : 
FR DD DD BBD, DD BD PP 
校 验 位 P;(G 王 1 一 4) 的 偶 校 验 的 结果 为 : 
P=D. WD,WD, WDD; WD 
P,=D 中 D: 中 D WD WD; 
P,=D,DD,DD,DD;, 
P,=D;@BD BDODD; 
在 上 述 4 个 公式 中 ,不 同 信息 位 出 现在 已 项 中 的 次 数 是 不 一 样 的 ,其 中 D, 和 D; 出 现 了 
3 次 ,而 D1 、.D; .D3、D; 、 De 、Ds 仅 出 现 了 两 次 ,此 时 不 同 代 码 的 汉 明 码 的 码 距 不 等 ,为 此 再 补 
充 一 位 P; 校 验 位 ,使 得 : 
P; 一 Di 中 D: 中 D: 由 Di 中 De 中 PD， 
在 这 种 安排 下 ,每 一 位 信息 位 都 均匀 地 出 现在 3 个 P; 值 的 形成 关系 中 。 当 任 一 信息 位 
发 生变 化 时 , 必 将 引起 3 个 P; 值 跟着 变化 , 即 合法 汉 明 码 的 码 距 都 为 4。 
(2) 校 验 
将 接收 到 的 汉 明 码 按 如 下 关系 进行 偶 校 验 : 
Si 一 PP, 中 D 中 D 由 D DD WDD, 
S: 王 PP 由 D, 中 D:; 中 D, 中 D, 中 D， 
S: 一 PP 中 D 中 D: 中 D OD; 
$= P, WDD; WD DDDD:; 
95 一 上 5 WDD OD, OD, WDD; WDD: OD: 
校 验 得 到 的 结果 值 S; 一 S:( 指 误 字 ) 能 反映 13 位 汉 明 码 的 出 错 情 况 : 
Q@ 当 S; 一 S; 为 00000 时 ,表明 无 错 。 
多 当 SS 一 S 中 仅 有 一 位 不 为 0 时 ,表明 是 某 一 校 验 位 出 错 或 3 位 汉 明 码 (包括 信息 位 
和 校 验 位 ) 同 时 出 错 。 由 于 后 一 种 出 错 的 可 能 性 很 小 , 故 认为 是 前 一 种 错 , 出 错位 是 该 S; 对 
应 的 P; 位 。 
@) 当 Si 一 S 中 有 两 位 不 为 0 时 ,表明 是 两 位 汉 明 码 同时 出 错 ,此 时 只 能 发 现 错误 ,而 无 
法 确定 出 错 的 位 置 。 
由 当 Si 一 S: 中 有 3 位 不 为 0 时 ,表明 是 1 位 信息 位 出 错 或 3 位 校 验 位 同时 出 错 , 巾 于 
后 一 种 错误 的 可 能 性 很 小 , 故 认为 是 前 一 种 错 。 出 错位 的 位 号 由 S 一 S 这 4 位 代码 值 指 
明 ,此 时 不 仅 能 检查 出 一 位 错 ,而 且 能 准确 的 定位 ,因此 可 以 纠正 这 个 错误 (将 该 位 变 反 )。 
@) 当 Si 一 SS 中 有 4 位 或 5 位 不 为 0 时 ,表明 出 错 情况 严重 ,系统 工作 可 能 出 现 故障 ,应 
检查 系统 硬件 的 正确 性 。 
急 和 由 两 种 出 错 的 情况 列 于 表 2-10 中 。 硅 表 中 仅 有 一 个 S; 不 为 0, 则 表示 P; 出 错 , 因 
为 是 校 验 位 出 错 , 故 此 时 并 不 需要 校正 它们 。 当 5 个 S; 位 有 3 个 为 1 时 , 则 表示 是 某 一 信息 
位 D; 出 错 。 出 错 信 息 位 的 汉 明 码 位 号 由 S, 一 S, 这 4 位 的 译 码 值 指出 (分 别 为 12、11、10、9、 
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7.6.5.3)。 例 如 , 当 S; 一 S;=00111 时 ,SS 一 S) 的 译 码 值 为 7, 即 对 应 五 ; (也 就 是 D, ) 位 
出 错 。 


表 2-10 汉 明 码 出 错 情 况 


例 2-17 设 有 一 个 8 位 信息 为 10101100 , 试 求 汉 明 编码 的 生成 和 校 验 过 程 。 
(1) 编码 生成 
校 验 位 长 度 为 5 位, 按 侦 校 验 有 : 
P, 一 0 中 0 由 1 由 0 由 0=1 
P; 王 0 由 1 由 1 由 1 由 0=1 
P:; 一 0 中 1 由 1 由 1=1 
PP 一 0 中 1 中 0 由 1=0 
P; 王 0 中 0 中 1 中 0 由 1 中 1=1 
故 可 得 到 用 二 进 制 表示 的 汉 明 码 为 : 
1101001101011 
下 画 线 表 示 校 验 位 在 汉 明 码 中 的 位 置 。 
(2) 校 验 
述 汉 明 码 经 传送 后 若 BCD;) 位 发 生 了 错误 , 原 码 字 就 变 为 ， 
1111001101011 


从 错 的 过 程 很 简单 ,只 要 将 接收 到 的 码 字 重新 进行 偶 校 验 即 可 ， 
Si 一 1 中 0 中 0 由 1 中 0 由 1=1 
S 一 1 中 0 由 1 由 1 由 1 由 1=1 
S: 一 1 中 0 中 1 中 1 由 1=0 
S 一 0 中 0 由 1 由 1 由 1=1 
Si 一 1 由 0 中 0 由 1 由 0 由 1 由 1=0 
故 指 误 字 为 01011, 其 中 低 4 位 有 效 , 相 应 的 十 进 制 数 是 11 ,指出 Hi 出 错 。 现 在 Hii 错 
成 了 1, 纠 错 就 是 将 五 :位 取 反 让 它 恢 复 为 0, 即 : 


错误 码 :1111001101011 
v 
纠正 后 : 1101001101011 
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2.6.3 循环 兄 余 校 验 码 


除了 奇偶 校 验 码 和 汉 明 码 外 ,在 计算 机 网 络 、 同 步 通信 以 及 磁 表 面 存储 顺 中 广泛 使 用 循 
环 宛 余 校 验 码 (CCyclic Redundancy Check ,CRC ) 。 

循环 元 余 校 验 码 是 通过 除法 运算 来 建立 有 效 信息 位 和 校 验 位 之 间 的 约定 关系 的 。 假 
设 , 待 编码 的 有 效 信息 以 多 项 式 M(CX) 表 示 , 将 它 左 移 奋 干 位 后 ,用 另 一 个 约定 的 多 项 式 CG 
(X) 去 除 , 所 产生 的 余数 R(X) 就 是 检验 位 。 有 效 信息 和 检验 位 相 拼 接 就 构成 了 CRC 码 。 
当 整 个 CRC 码 被 接收 后 , 仍 用 约定 的 多 项 式 GCX) 去 除 , 若 余数 为 0 表明 该 代码 是 正确 的 ; 
各 余数 不 为 0 则 表明 某 一 位 出 错 , 青 进一步 由 余数 值 确 定 出 错 的 位 置 ,以 便 进行 纠正 。 


1. 循环 元 余 校 验 码 的 编码 方法 


循环 元 余 校 验 码 是 由 两 部 分 组 成 的 ,如 图 2-13 所 示 。 左 边 为 信息 位 ,右边 为 校 验 位 。 
言 息 位 》 V 。 验 位 》 立 , 则 该 Li 1 和 
右 信 息 位 为 六 位 , 校 验 位 为 天 位 , 则 该 校 验 码 被 称 为 CN 十 py pd 


站 
循环 元 余 校 验 码 编 码 规律 如 下 : 
@ 把 待 编码 的 N 位 有 效 信息 表示 为 多 项 式 M(CX)。 图 2-13 循环 元 余 校 验 
@ 把 MCX) 左 移 K 位 ,得 到 M(X) X Xr ,这样 空 出 了 天 mm 


位 ,以 便 拼 装 天 位 余数 ( 即 校 验 位 ) 。 
@) 选取 一 个 天 十 1 位 的 产生 多 项 式 G(CX) ,对 M(X) XX* 做 模 2 除 。 
MCX) XXK RCUX) 
G(X) G(X) 
@ 把 左 移 KK 位 以 后 的 有 效 信息 与 余数 R(X) 做 模 2 加 减 ,拼接 为 CRC 码 ,此 时 的 CRC 
码 共有 N 十 K 位 。 


二 Q(X) 十 


M(X)XX*+R(X)=Q(X) XG(X) 
注意 : CRC 校 验 技术 中 使 用 的 模 2 运算 是 一 种 二 进 制 运算 , 模 2 运算 与 四 则 运算 不 同 
之 处 在 于 它 不 用 考虑 进位 和 借 位 。 
例 2-18 选择 产生 多 项 式 为 1011, 把 4 位 有 效 信息 1100 编 成 CRC 码 。 
M(X) 一 X 十 X = 1100 
M(CX) XX 一 X' 十 X” = 1100000 
G(X) = 二 XX 十 XX 十 1] = 1011 


MX)X X; 1100000 _ 010 
G(X) 1011 ey 1011 
M(X) x XR(X) 一 1100000 十 010 = 1100010 
这 种 CRC 码 称 为 (7,4) 码 。 


2. 循环 元 余 校 验 码 的 校 验 与 纠 错 


把 接收 到 的 CRC 码 用 约定 的 生成 多 项 式 G(X) 去 除 ,如 果 正 确 , 则 余数 为 0; 如 果 某 一 
位 出 错 , 则 余数 不 为 0。 不 同 的 位 数 出 错 其 余数 不 同 ,余数 和 出 错位 序号 之 间 有 唯一 的 对 应 
关系 。 表 2-11 列 出 了 (7,4) 码 的 出 错 模式 。 
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表 2-11 (7,4) 码 的 出 错 模 式 (G(X)= 二 1011) 


Sy 
人 
间 
> 
. 
村 
> 
让 
机 
> 
沙 
过 
进 
他 


Hi 
光 
日 


OO OO OO OO OO OO ~|oO 


错误 码 


= 
OO OO OO ~ OO OO OoO|DO 
pho el hd hk CE hd | hh 
一 和 AI 


O OO OO OO ~ O OoO|DO 


pO | 


如 果 某 一 位 出 错 , 则 余数 不 为 0, 对 此 余数 补 0 后 , 当 作 被 除数 再 继续 除 下 去 ,余数 将 按 
表 2-11 的 顺序 循环 。 例 如 ,第 七 位 (A; ) 出 错 , 余 数 为 001 ,把 其 补 0 后 再 除 以 G(CX) ,第 二 次 
余数 为 010, 以 后 依次 分 别 为 100、011、110、111、101;, 然 后 又 回 到 001 ,反复 循 环 ,这 就 是 “ 循 
环 码 ” 词 的 来 源 。 根 据 循环 码 的 特征 ,一 边 对 余数 补 0 继续 做 模 2 除法 ,同时 让 被 检测 的 校 
验 码 循环 左 移 。 当 余数 为 101 时 ,原来 出 错 的 A; 位 已 移 到 A 的 位 置 ,通过 异 或 门将 其 求 反 
纠正 ,在 下 一 次 循环 左 移 时 送 回 A;。 所 以 , 移 满 一 个 循环 (7 次 ) ,就 得 到 一 个 纠正 的 码 字 。 


3. 生成 多 项 式 的 选择 


生成 多 项 式 被 用 来 生成 CRC 码 ,并 不 是 任何 一 个 KK 十 1 位 多 项 式 都 可 以 作 生 成 多 项 式 
用 的 , 它 应 满足 下 列 要 求 : 
@ 任何 一 位 发 生 错误 都 应 使 余数 不 为 0。 
@ 不 同位 发 生 错 误 应 当 使 余数 不 同 。 
G) 对 余数 做 模 2 除法 ,应 使 余数 循环 。 
常用 的 生成 多 项 式 有 多 个 ,读者 可 从 有 关 资 料 上 查 到 可 选 生 成 多 项 式 。 在 计算 机 和 通 
信 系 统 中 广泛 使 用 下 述 两 个 生成 多 项 式 ,它们 是 : 
GCX) 一 Xi 十 X15 十 X2 十 1 
GCX) 一 Xi 十 X12 十 Xe 十 1 


习 题 


2-1 设 机 器 数 的 字 长 为 8 位 ( 含 1 位 符号 位 ) ,分 别 写 出 下 列 各 二 进 制 数 的 原 码 、 补 码 和 反 码 。 
0， 一 0， 0.1000， 一 0.1000， 0.1111， 一 0.1111， 1101， 一 1101 
2-2 写 出 下 列 各 数 的 原 码 、 补 码 和 反 码 。 
了 和 上 NE St 
16 ” 16” 16” 16° 16° 16 
2-3 已 知 下 列 数 的 原 码 表示 ,分 别 写 出 它们 的 补 码 表示 。 
[Xj 二 0.10100， [LXJ] 一 1.10111 
2-4 已 知 下 列 数 的 补 码 表示 ,分 别 写 出 它们 的 真 值 。 
[X]# 一 0.10100， [Xj]#=1.10111 
2-9 设 一 个 二 进 制 小 数 XX 过 0, 表示 成 X=0.AlA,A,;A,A;A; ,其 中 Al 一 As 取 1 或 0。 


士 0， 


数据 的 机 器 层次 表示 


(1) 若 要 X> 子 , 则 4 一 As 要 满足 什么 条 件 ? 


(2) 若 要 X 之 二 , 则 A, 一 A, 要 满足 什么 条 件 ? 


(3) 若 要 村 >>X> 二, 则 A, 一 A, 要 满足 什么 条 件 ? 
2-6 设 LX] 王 1. AAA AAA 。 


(1) 若 要 X> 一 村 , 骨 Ai 一 As 要 满足 什么 条 件 ? 


(2) 车 要 一 二 之 X 之 一 闻 , 则 A, 一 A, 要 满足 什么 条 件 ? 


2-7 若 将 习题 2-6 中 [Xj] 蒜 改 为 LXj] ,那么 结果 如 何 ? 
2-8 一 个 nn 位 字 长 的 二 进 制定 点 整数 ,其 中 1 位 为 符号 位 ,分 别 写 出 在 补 码 和 反 码 两 种 情况 下 : 


(1) 模 数 。 (2) 最 大 的 正 数 。 

(3) 最 负 的 数 。 (4) 符号 位 的 权 。 

(5) 一 1 的 表示 形式 。 (6) 0 的 表示 形式 。 

2-9 某 计 算 机 字 长 为 16 位 , 简 述 下 列 几 种 情况 下 所 能 表示 数值 的 范围 。 
(1) 无 符号 整数 。 (2) 用 原 码 表示 定点 小 数 。 

(3) 用 补 码 表 示 定 点 小 数 。 (4) 用 原 码 表 示 定 点 整数 。 


(5) 用 补 码 表示 定点 整数 。 

2-10 某 计 算 机 字 长 为 32 位 , 试 分 别 写 出 无 符号 整数 和 人 带 符 号 整数 ( 补 码 ) 的 表示 范围 (用 十 进 制 数 
表示 ) 。 

2-11 假设 机 器 数字 长 8 位 ,大 机 器 数 为 81H, 当 它 分 别 代表 原 码 、 补 码 、 反 人 码 和 移 码 时 ,等 价 的 十 进 
制 整数 分 别 是 多 少 ? 

2-12 设计 补 码 表示 法 的 目的 是 什么 ? 列表 写 出 十 0、. 十 25、 十 127、 一 127 及 一 128 的 8 位 二 进 制 原 
码 ` 反 码 、 补 码 和 移 码 表示 ,并 将 补 码 用 十 六 进 制 表示 出 来 。 

2-13 十 进 制 数 12345 用 32 位 补 码 整数 和 32 位 浮 点 数 (IEEE 754 标准 ) 表 示 的 结果 各 是 什么 (用 十 
六 进 制 表示 )? 

2-14 某 浮 点 数字 长 为 12 位 ,其 中 , 阶 符 为 1 位 , 阶 码 数 值 为 3 位 ; 数 符 为 1 位 ,尾数 数值 为 7 位 。 阶 
码 以 2 为 底 , 阶 码 和 尾数 均 用 补 码 表示 。 它 所 能 表示 的 最 大 正 数 是 多 少 ? 最 小 规格 化 正 数 是 多 少 ? 绝对 
值 最 大 的 负数 是 多 少 ? 

2-15 某 浮 点 数字 长 为 16 位 ,其 中 , 阶 码 部 分 为 6 位 ( 含 1 位 阶 符 ), 移 码 表 示 , 以 2 为 底 ; 尾 数 部 分 为 
10 位 ( 含 1 位 数 符 ,位 于 尾数 最 高 位 ), 补 码 表示 ,规格 化 。 分 别 写 出 下 列 情 况 的 二 进 制 代 码 与 十 进 制 真 值 。 

(1) 非 零 最 小 正 数 。 (2) 最 大 正 数 。 

(3) 绝对 值 最 小 负数 。 (4) 绝对 值 最 大 负数 。 

2-16 一 浮 点 数 , 其 阶 码 部 分 为 p 位 ,尾数 部 分 为 gq 位 ,各 包含 1 位 符号 位 , 均 用 补 码 表示 ;尾数 基数 
r 二 2, 该 浮 点 数 格式 所 能 表示 数 的 上 限 、 下 限 及 非 零 的 最 小 正 数 是 多 少 ? 写 出 表达 式 。 

2-17 车 上 题 尾数 基数 r=16, 按 上 述 要 求 写 出 表达 式 。 

2-18 某 浮 点 数字 长 为 32 位 ,格式 如 下 。 其 中 , 阶 码 部 分 为 8 位 ,以 2 为 底 , 移 码 表示 ;尾数 部 分 一 共 
24 位 ( 含 1 位 数 符 ), 补 码 表 示 。 现 有 一 浮 点 代码 为 (8C5A3E00)is , 试 写 出 它 所 表示 的 十 进 制 真 值 。 


0 FF 人 31 


尾数 


2-19 试 将 (一 0.1101), 用 IEEE 短 浮 点 数 格式 表示 出 来 。 
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2-20 将 下 列 十 进 制 数 转换 为 IEEE 短 浮 点 数 : 

(1) 28.75 (2) 624 (3) 一 0. 625 
(4) 十 0.0 (5) 一 1000.5 

2-21 将 下 列 IEEE 短 浮 点 数 转换 为 十 进 制 数 : 

(1) 11000000 11110000 00000000 00000000 

(2) 00111111 00010000 00000000 00000000 

(3) 01000011 10011001 00000000 00000000 

(4) 01000000 00000000 00000000 00000000 

(5) 01000001 00100000 00000000 00000000 

(6) 00000000 00000000 00000000 00000000 

2-22 ”对 下 列 ASCII 码 进行 译 码 。 

1001001， 0100001， 1100001， 1110111， 1000101, 1010000， 1010111， 0100100 
2-23 以 下 列 形 式 表 示 (5382)io 。 


(1) 8421 码 。 (2) 余 3 码 。 (3) 2421 码 。 (4) 二 进 制 数 。 
2-24 填写 下 列 代 码 的 奇偶 校 验 位 , 现 设 为 奇 校 验 。 

10100001 

00011001 

01001110 


2-25 已 知 下 面 数 据 块 约定 : 横向 校 验 、 纵 问 校 验 均 为 奇 校 验 , 指 出 至 少 有 多 少 位 出 错 。 
A:1 A。 As 4，A4，A4，A4A，A4， 校 验 位 


1 0 0 1 1 0 1 1 —> 0 
0 0 1 1 0 1 0 1 > 1 
1 1 0 1 0 0 0 0 > 0 
1 1 1 0 0 0 0 0 > 0 
0 1 0 0 1 1 1 1 —> 0 
yr/ 

校 验 位 1 0 1 0 1 1 1 1 


2-26 求 有 效 信息 位 为 01101110 的 汉 明 校 验 码 。 
2-27 设计 算 机 准备 传送 的 信息 是 1010110010001111, 生 成 多 项 式 是 X 十 X? 十 1, 计 算 校 验 位 , 写 出 
CRC 码 。 
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指令 和 指令 系统 是 计算 机 中 最 基本 的 概念 。 指 令 是 指示 计算 机 执行 菜 些 操作 的 命令 ， 
一 台 计 算 机 的 所 有 指令 的 集合 构成 该 机 的 指令 系统 ,也 称 指令 集 。 指 令 系 统 是 计算 机 的 主 
要 属性 ,位 于 人 硬件 和 软件 的 交界 面 上 。 本 草 将 讨论 一 般 计 算 机 的 指令 系统 所 涉及 的 基本 
问题 。 


3.1 指令 格式 


一 台 计算 机 指令 格式 的 选择 和 确定 涉及 多 方面 的 因素 ,如 指令 长 度 、 地 址 码 结构 以 及 操 
作 码 结构 等 ,是 一 个 很 复杂 的 问题 , 它 与 计算 机 系统 结构 .数据 表示 方法 .指令 功能 设计 等 都 
密切 相关 。 


3.1.1 机 器 指令 的 基本 格式 
一 条 指令 就 是 机 器 语言 的 一 个 语句 , 它 是 一 组 有 意义 的 二 进 制 代 码 ,指令 的 基本 格式 


如 下 : 


其 中 ,操作 码 指 明了 指令 的 操作 性 质 及 功能 ,地 址 码 则 给 出 了 操作 数 的 地 址 。 

指令 的 长 度 是 指 一 条 指令 中 所 包含 的 二 进 制 代码 的 位 数 , 它 取决 于 操作 码 字 段 的 长 度 、 
操作 数 地 址 的 个 数 及 长 度 。 指 令 长 度 与 机 帮 字 长 没有 固定 的 关系 , 它 可 以 等 于 机 带 字 长 ,也 
可 以 大 于 或 小 于 机 融 字 长 。 在 字 长 较 短 的 小 型 微型 计算 机 中 ,大 多 数 指令 的 长 度 可 能 大 于 
机 融 的 字 长 ;而 在 字 长 较 长 的 大 型 .中 型 计算 机 中 ,大 多 数 指令 的 长 度 则 往往 小 于 或 等 于 机 
估 的 字 长 。 通 律 ,把 指令 长 度 等 于 机 天 字 长 的 指令 称 为 单字 长 指令 ;指令 长 度 等 于 半 个 机 天 
字 长 的 指令 称 为 半 字 长 指令 ;指令 长 度 等 于 两 个 机 天 字 长 的 指令 称 为 双 字 长 指令 。 

在 一 个 指令 系统 中 , 夺 所 有 指令 的 长 度 都 是 相等 的 ,就 称 该 指令 系统 为 定 长 指令 字 结 
构 。 定 长 结构 指令 系统 控制 简单 ,但 不 够 灵活 。 夺 各 种 指令 的 长 度 随 指令 功能 而 异 ,就 称 该 
指令 系统 为 变 长 指令 字 结 构 。 现 代 计 算 机 广泛 采用 变 长 指令 字 绪 构 ,指令 的 长 度 能 短 则 短 ， 
需 长 则 长 ,如 80x86 的 指令 长 度 从 一 个 字 节 到 十 几 个 字 节 不 等 。 杰 长 结构 指令 系统 灵活 ,能 
充分 利用 指令 长 度 ,但 指令 的 控制 较为 复杂 。 
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3.1.2 地 址 码 结 构 


计算 机 执行 一 条 指令 所 需要 的 全 部 信息 都 必须 包含 在 指令 中 。 对 于 一 般 的 双 操 作 数 运 
算 类 指令 来 说 ,除去 操作 码 (Operation Code) 之 外 ,指令 还 应 包含 以 下 信息 : 

J 第 一 操作 数 地 址 ,用 Al 表 示 。 

@@ 第 二 操作 数 地 址 ,用 A, 表 示 。 

@ 操作 结果 存放 地 址 ,用 A; 表 示 。 

9 下 一 条 将 要 执行 指令 的 地 址 ,用 A 表示。 

这 些 信 息 可 以 在 指令 中 明显 地 给 出 , 称 为 显 地 址 ;也 可 以 依照 某 种 事先 的 约定 ,用 隐 合 
的 方式 给 出 , 称 为 隐 地 址 。 下 面 从 地 址 结构 的 角度 来 介绍 几 种 指令 格式 。 


1. 四 地 址 指令 
前 述 的 4 个 地 址 信息 都 在 地 址 字段 中 明显 地 给 出 ,其 指令 的 格式 为 : 


oP AAA A 


(A1)OP(A;,)—A; 
A 二 下 一 条 将 要 执行 指令 的 地 址 
其 中 ,OP 表示 具体 的 操作 , A; 表示 地 址 , (A;) 表 示 存 放 于 该 地 址 中 的 内 容 。 
这 种 格式 的 主要 优点 是 直观 ,下 一 条 指令 的 地 址 明显 。 但 是 ,最 严重 的 缺点 是 指令 的 长 
度 太 长 ,如 果 每 个 地 址 为 16 位 ,整个 地 址 码 字 段 就 要 长 达 64 位 ,所 以 这 种 格式 是 不 切实 
际 的 。 


2. 三 地 址 指令 


正常 情况 下 ,大 多 数 指令 按 顺 序 依 次 被 从 主 存 中 取出 来 执行 ,只 有 在 遇 到 转移 指令 时 ， 
程序 的 执行 顺序 才 会 改变 。 因 此 ,可 以 用 一 个 程序 计数 大 (Program Counter,PC) 来 存放 指 
令 地 址 。 通 常 每 执行 一 条 指令 ,PC 就 自动 加 1( 设 每 条 指令 只 占 一 个 主 存单 元 ) ,直接 得 到 
将 要 执行 的 下 一 条 指令 的 地 址 。 这 样 ,指令 中 就 不 必 上 青 明 显 地 给 出 下 一 条 指令 的 地 址 了 。 
三 地 址 指令 格式 为 : 


oP AAA 


(A1)OP(A,)—A, 
(PC) 十 1 一 PC( 隐 含 ) 
执行 一 条 三 地 址 的 双 操 作 数 运算 指令 ,至 少 需要 访问 4 次 主 存 。 第 一 次 取 指 令 本 身 ,第 
二 次 取 第 一 操作 数 , 第 三 次 取 第 二 操作 数 , 第 四 次 保存 运算 结果 。 
这 种 格式 省 去 了 一 个 地 址 ,但 指令 长 度 仍 比较 长 ,所 以 只 在 字 长 较 长 的 大 型 .中 型 计算 
机 中 使 用 ,小 型 微型 计算 机 中 很 少 使 用 。 


3. 二 地 址 指令 


三 地 址 指令 执行 完 后 , 主 存 中 的 两 个 操作 数 均 不 会 被 破坏 。 然 而 ,通常 并 不 一 定 需要 有 完 
整 的 保留 两 个 操作 数 。 例 如 ,可 让 第 一 操作 数 地 址 同时 兼作 存放 结果 的 地 址 (目的 地 址 ) ,这 
样 即 得 到 了 二 地 址 指令 ,其 格式 为 : 


OP AAA 


(A1)OP(A,)—A 
(PC) 十 1 一 PC( 隐 含 ) 
其 中 ,Ai 为 目的 操作 数 地 址 ,A: 为 源 操作 数 地 址 。 
注意 : 指令 执行 之 后 ,目的 操作 数 地 址 中 原 存 的 内 容 已 被 破坏 了 。 
执行 一 条 二 地 址 的 双 操 作 数 运 算 指 令 ,同样 至 少 需 要 访问 4 次 主 存 。 


4. 一 地 址 指令 
一 地 址 指令 顾名思义 只 有 一 个 显 地 址 , 它 的 指令 格式 为 : 


oP | A 


一 地 址 指令 只 有 一 个 地 址 ,那么 男 一 个 操作 数 来 日 何方 呢 ? 指令 中 虽 未 明显 给 出 ,但 按 
事先 约定 ,这 个 隐 含 的 操作 数 就 放 在 一 个 专门 的 寄存 硕 中 。 因 为 这 个 寄存 天 在 连续 运算 时 ， 
保存 着 多 条 指令 连续 操作 的 累计 结果 , 故 称 为 昧 加 寄存 器 (Accumulator,Acc) 。 

指令 的 合 义 ; 

(Acc)OP(A;) 一 Acc 
(PC) 十 1 一 PC( 隐 含 ) 

执行 一 条 一 地 址 的 双 操 作 数 运算 指令 ,只 需要 访问 两 次 主 存 。 第 一 次 取 指 令 本 身 , 第 二 
次 取 第 二 操作 数 。 第 一 操作 数 和 运算 结果 都 放 在 累加 寄存 硕 中 ,所 以 恋 取 和 和 存 人 都 不 需要 
访问 主 存 。 

5. 零 地 址 指令 

零 地 址 指令 格式 中 只 有 操作 码 字 段 ,没有 地 址 码 字 段 ,其 格式 为 : 


和 零 地 址 的 算术 人 逻辑 类 指令 是 用 在 堆栈 计算 机 中 的 ,堆栈 计算 机 没有 一 般 计算 机 中 必 备 
的 通用 寄存 右 , 因 此 堆栈 就 成 为 提供 操作 数 和 保存 运算 结果 的 唯一 场所 。 通 党 ,参加 算术 好 
辑 运 算 的 两 个 操作 数 隐 含 地 从 堆栈 顶部 弹出 , 送 到 运算 需 中 进行 运算 ,运算 的 结果 再 隐 含 地 
压 人 堆栈 。 有 关 扒 栈 的 概念 将 在 稍 后 介绍 。 

指令 中 地 址 个 数 的 选取 要 考虑 诸多 的 因素 。 从 纵 短 程序 长 度 、 用 户 使 用 方便 、 增 加 操作 
并 行 度 等 方面 来 看 ,选用 三 地 址 指令 格式 较 好 ;从 缩短 指令 长 度 ,减少 访 存 次 数 、 简 化 便 件 设 


EE 
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计 等 方面 来 看 ,一 地 址 指令 格式 较 好 。 对 于 同一 个 问题 ,用 三 地 址 指令 编写 的 程序 最 短 ,但 
指令 长 度 ( 程 序 存 储量 ) 最 长 ;而 用 二 、 一 、 堆 地址 指令 来 编写 程序 ,程序 的 长 度 一 个 比 一 个 
长 ,但 指令 的 长 度 一 个 比 一 个 短 。 表 3-1 给 出 了 不 同 地 址 数 指令 的 特点 及 适用 场合 。 


表 3-1 不 同 地 址 数 指令 的 特点 及 适用 场合 


地 址 数量 | 程序 长 度 | 程序 存储 量 适用 场合 
短 最 大 二 般 


三 地 址 以 回 量 .矩阵 运算 为 主 
二 地 址 一 般 很 大 一 般 不 宜 采 用 

一 地 址 较 长 较 大 连续 运算 ,硬件 结构 简单 
等 地 址 最 长 最 小 骨 套 ,递归 问题 


前 面 介 绍 的 操作 数 地 址 都 是 指 主 存单 元 的 地 址 ,实际 上 许多 操作 数 可 能 是 存放 在 通用 
寄存 器 里 的 。 计 算 机 在 CPU 中 设置 了 相当 数量 的 通用 寄存 器 ,用 它们 来 暂 存 运 算数 据 或 
中 间 结 果 ,这 样 可 以 大 大 减少 访 存 次 数 , 提 高 计算 机 的 处 理 速度 。 实 际 使 用 的 二 地 址 指令 多 
为 二 地 址 R( 通 用 寄存 器 ) 型 ,一般 通用 寄存 器 数量 有 8 一 32 个 ,其 地 址 (或 称 寄存 需 编 号 ) 有 
3 一 5 位 就 可 以 了 。 由 于 二 地 址 R 型 指令 的 地 址 码 字 段 很 短 , 且 操作 数 就 在 寄存 器 中 ,所 以 
这 类 指令 的 程序 存储 量 最 小 ,程序 执行 速度 最 快 ,在 小 型 微型 计算 机 中 被 大 量 使 用 。 


3.1.3 指令 的 操作 码 


指令 系统 中 的 每 一 条 指令 都 有 一 个 唯一 确定 的 操作 码 ,指令 不 同 ,其 操作 码 的 编码 也 不 
同 。 通 常 ,希望 用 尽 可 能 短 的 操作 码 字 段 来 表达 全 部 的 指令 。 指 令 操 作 码 的 编码 可 以 分 为 
规整 型 和 非 规整 型 两 类 编码 。 


1. 规整 型 编码 ( 定 长 编码 ) 


这 是 一 种 最 简单 的 编码 方法 ,操作 码 字 段 的 位 数 和 位 置 是 固定 的 。 为 了 能 表示 整个 指 
令 系统 中 的 全 部 指令 ,指令 的 操作 码 字 段 应 当 具 有 足够 的 位 数 。 

假定 指令 系统 共有 m 条 指令 ,指令 中 操作 码 字 段 的 位 数 为 N 位 , 则 有 如 下 关系 式 : 

m2™ 
所 以 ， 
N 宇 log,m 

定 长 编码 对 于 简化 硬件 设计 ,减少 指令 译 码 的 时 间 是 非常 有 利 的 ,在 字 长 较 长 的 大 型 、 
中 型 计算 机 及 超级 小 型 计算 机 上 广泛 采用 。 例 如 ,IBM 370 机 ( 字 长 32 位 ) 中 采用 的 就 是 这 
种 方式 。IBM 370 机 的 指令 可 分 为 3 种 不 同 的 长 度 形式 : 半 字 长 指令 (16 位 ) .单字 长 指令 
(32 位 ) 和 一 个 半 字 长 指令 (48 位 ) ,共有 5 种 格式 ,如 图 3-1 所 示 。 

从 图 3-1 可 以 看 出 ,在 IBM 370 机 中 不 论 指令 的 长 度 为 多 少 位 ,其 操作 码 字 段 一 律 都 是 
8 位 。8 位 操作 码 允 许 容 纳 256 条 指令 。 而 实际 上 在 IBM 370 机 中 仅 有 183 条 指令 ,存在 
着 极 大 的 信息 元 余 , 这 种 信息 元 余 的 编码 也 称 为 非法 操作 码 。 


2. 非 规整 型 编码 ( 变 长 编码 ) 
变 长 编码 的 操作 人 码 字 段 的 位 数 不 固 定 , 且 分 散 地 放 在 指令 字 的 不 同位 置 上 。 这 种 方式 能 


8 4 4 
RR 型 [OP TRITR] 
8 4 4 4 12 
RX 型 | OP |Ri|X|lB,| D 
8 4 4 4 
8 8 4 及 
sm [or Tb Tel ob 


8 8 4 
SS 型 | OP | LIL |B| DD |B 
3-1 IBM 370 机 的 指令 格式 


够 有 效 地 压缩 指令 中 操作 码 字 段 的 平均 长 度 ,在 字 长 较 短 的 小 型 .微型 计算 机 上 广泛 采用 。 例 
如 ,PDP-11 机 ( 字 长 16 位 ) 中 采用 的 就 是 这 种 方式 。PDP-11 机 的 指令 分 为 单字 长 .二 字 长 ,三 
字 长 3 种 ,操作 码 字 段 占 4 一 16 位 不 等 ,可 遍及 整个 指令 长 度 , 其 指令 格式 如 图 3-2 所 示 。 


0 16 

Bz)LorP| S|]p| 地址 | 

-=K 4 6 6 16 16 

可 位 )LOP [S[D[ 地址 | 地 址 | 
3-2 PDP-11 机 的 指令 格式 


显然 ,操作 码 字段 的 位 数 和 位 置 不 固定 将 增加 指令 译 码 和 分 析 的 难度 ,使 得 控制 带 的 设 
计 复 杂 化 。 

最 常用 的 非 规 整 型 编码 方式 是 扩展 操作 码 法 。 因 为 如 果 指 令 长 度 一 定 , 则 地 址 码 与 操 
作 码 字段 的 长 度 是 相互 制约 的 。 为 了 解决 这 一 矛盾 ,让 操作 数 地 址 个 数 多 的 指令 (三 地 址 指 
令 ) 的 操作 码 字 段 短 些 ,操作 数 地 址 个 数 少 的 指令 (一 或 零 地 址 指令 ) 的 操作 码 字 段 长 些 ,这 
样 既 能 充分 地 利用 指令 的 各 个 字段 ,又 能 在 不 增加 指令 长 度 的 情况 下 扩展 操作 码 的 位 数 ,使 
它 能 表示 更 多 的 指令 。 例 如 , 设 某 计 算 机 的 指令 长 度 为 16 位 ,操作 码 字 段 为 4 位 ,有 3 个 4 
位 的 地 址 码 字 段 , 其 格式 为 : 


如 果 按 照 定 长 编码 的 方法 ,4 位 操作 码 最 多 只 能 表示 16 条 不 同 的 三 地 址 指令 。 假 设 指 
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令 系 统 中 不 仅 有 三 地 址 指令 ,还 有 二 地 址 指令 .一 地 址 指令 和 零 地 址 指令 ,利用 扩展 操作 码 
法 可 以 使 在 指令 长 度 不 变 的 情况 下 ,指令 的 总 数 远 远大 于 16 条 。 例 如 ,指令 系统 中 要 求 有 
15 条 三 地 址 指令 、15 条 二 地 址 指令 、15 条 一 地 址 指令 和 16 条 零 地 址 指令 , 共 61 条 指令 。 
显然 ,只 有 4 位 操作 码 是 不 够 的 ,解决 的 方法 就 是 向 地 址 码 字 段 扩展 操作 码 的 位 数 。 扩 展 的 
方法 如 下 : 

QD 4 位 操作 码 的 编码 0000 一 1110 定义 了 15 条 三 地 址 指令 , 留 下 1111 作为 扩展 窗口 ， 
与 下 一 个 4 位 (A) 组 成 一 个 8 位 的 操作 码 字 段 。 

@ 8 位 操作 码 的 编码 11110000 一 11111110 定义 了 15 条 二 地 址 指令 , 留 下 11111111 作 
为 扩展 窗口 ,与 下 一 个 4 位 (A;) 组 成 一 个 12 位 的 操作 码 字 段 。 

@ 12 位 操作 码 的 编码 111111110000~111111111110 定义 了 15 条 一 地 址 指令 ,扩展 窗 
口 为 111111111111, 与 A; 组 成 16 位 的 操作 码 字 段 。 

@ 最 后 ,16 条 零 地 址 指令 由 16 位 操作 码 的 编码 1111111111110000 一 1111111111111111 
给 出 。 

根据 指令 系统 的 要 求 ,扩展 操作 码 的 组 合 方案 可 以 有 很 多 种 ,但 有 以 下 两 点 要 注意 : 

e。 不 允许 短 码 是 长 码 的 前 级 , 即 短 码 不 能 与 长 码 的 开始 部 分 的 代码 相同 ,否则 将 无 法 保 

证 解码 的 唯一 性 和 实时 性 。 
e 各 条 指令 的 操作 码 一 定 不 能 重复 ,而 且 各 类 指令 的 格式 安排 应 统一 规整 。 


3.2 寻 址 技术 


所 谓 寻 址 , 指 的 是 寻找 操作 数 的 地 址 或 下 一 条 将 要 执行 的 指令 地 址 , 寻 址 技术 是 计算 机 
设计 中 人 硬件 对 软件 最 早 提 供 支 持 的 技术 之 一 。 寻 址 技术 包括 编 址 方式 和 寻 址 方式 。 


3.2.1 编 址 方式 
在 计算 机 中 , 编 址 方式 是 指 对 各 种 存储 设备 进行 编码 的 方式 。 
1. 编 址 


通常 ,指令 中 的 地 址 码 字 段 将 指出 操作 数 的 来 源 和 去 癌 ,而 操作 数 则 存放 在 相应 的 存储 
设备 中 。 在 计算 机 中 需要 编 址 的 设备 主要 有 CPU 中 的 通用 寄存 器、 主 存储 器 和 输入 输出 
设备 3 种 。 

要 对 寄存 器 、 主 存储 器 和 输入 输出 设备 进行 访问 ,首先 必须 对 它们 进行 编 址 。 就 像 一 个 
大 楼 有 许多 房间 ,首先 必须 给 每 一 个 房间 编 上 一 个 唯一 的 号 码 , 人 们 才能 据 此 找到 需要 的 房 
间 一 样 。 

如 果 存 储 设 备 是 CPU 中 的 通用 寄存 需 , 那 么 在 指令 字 中 应 给 出 寄存 需 编 号 ;如 果 是 主 
存 的 一 个 存储 单元 ,那么 在 指令 字 中 应 给 出 该 主 存单 元 的 地 址 ;如 果 是 输入 输出 设备 (接口 ) 
中 的 一 个 寄存 融 , 那 么 指令 字 中 应 给 出 设备 编号 或 设备 端口 地 址 或 设备 映像 地 址 (与 主 存 地 
址 统一 编 址 时 )。 


2. 编 址 单位 
目前 第 用 的 编 址 单位 有 字 编 址 、 字 节 编 址 和 位 编 址 。 


(1) 字 编 址 

字 编 址 是 实现 起 来 最 容易 的 一 种 编 址 方式 ,这 是 因为 每 个 编 址 单位 与 访问 单位 相 一 致 ， 
即 每 个 编 址 单位 所 包含 的 信息 量 ( 二 进 制 位 数 ) 与 访问 一 次 寄存 器 、 主 存 所 获得 的 信息 量 相 
同 。 早 期 的 大 多 数 机 需 都 采用 这 种 编 址 方式 。 

在 采用 字 编 址 的 机 需 中 ,每 执行 一 条 指令 ,程序 计数 器 加 1; 每 从 主 存 中 读 出 一 个 数 
据 ,地 址 计数 需 加 1。 这 种 控制 方式 实现 起 来 简单 ,地址 信息 没有 任何 浪费 。 但 它 的 主要 
缺点 是 不 支持 非 数 值 应 用 ,而 目前 在 计算 机 的 实际 应 用 领域 中 , 非 数 值 应 用 已 超过 数值 
应 用 。 

(2) 字 节 编 址 

目前 使 用 最 普遍 的 编 址 方式 是 字 节 编 址 ,这 是 为 了 适应 非 数 值 应 用 的 需要 。 字 节 编 址 
方式 使 编 址 单位 与 信息 的 基本 单位 (一 个 字 节 ) 相 一 致 ,这 是 它 的 最 大 优点 。 然 而 ,如 果 主 存 
的 访问 单位 也 是 一 个 字 节 的 话 ,那么 主 存 的 带宽 就 太 罕 了 ,所 以 编 址 单位 和 主 存 的 访问 单位 
是 不 相同 的 。 通 和 常 主 存 的 访问 单位 是 编 址 单位 的 若干 倍 。 

在 采用 字 节 编 址 的 机 器 中 ,如 果 指 令 长 度 是 32 位 ,那么 每 执行 完 一 条 指令 ,程序 计数 需 
要 加 4。 如 果 数 据 字 长 是 32 位, 当 连续 访问 存储 希 时 ,每 读 写 完 一 个 数据 字 ,地 址 寄存 硕 要 
加 4。 由 此 可 见 , 字 节 编 址 方式 存在 着 地 址 信息 的 浪费 。 

(3) 位 编 址 

有 部 分 计算 机 系统 采用 位 编 址 方式 ,如 STAR-100 巨型 计算 机 等 。 这 种 编 址 方式 的 地 
址 信息 浪费 更 大 。 


3. 指令 中 地 址 码 的 位 数 


指令 格式 中 每 个 地 址 码 的 位 数 是 与 主 存 容量 和 最 小 寻 址 单位 ( 即 编 址 单位 ) 有 关联 的 。 
主 存 容量 越 大 ,所 需 的 地 址 码 位 数 就 越 长 。 对 于 相同 容量 来 说 ,如 果 以 字 节 为 最 小 寻 址 单 
位 ,那么 地 址 码 的 位 数 就 需要 长 些 , 但 是 可 以 方便 地 对 每 一 个 字符 进行 处 理 ; 如果 以 字 为 最 
小 寻 址 单位 (假定 字 长 为 16 位 或 更 长 ) ,那么 地 址 码 的 位 数 可 以 减少 ,但 对 字符 操作 比较 困 
难 。 例 如 , 设 东 计算 机 主 存 容 量 为 2” 个 字 节 ,机 带 字 长 32 位 , 右 最 小 寻 址 单位 为 字 节 ( 按 字 
节 编 址 ) ,其 地 址 码 应 为 20 位 ; 奢 最 小 寻 址 单位 为 字 ( 按 字 编 址 ) ,其 地 址 码 只 需 18 位 。 从 减 
少 指令 长 度 的 角度 看 ,最 小 寻 址 单位 越 大 越 好 ;而 从 对 字符 或 位 的 操作 是 否 方便 的 角度 看 ， 
最 小 寻 址 单位 越 小 越 好 。 


3.2.2 指令 村 址 和 数据 导 址 


寻 址 可 以 分 为 指令 寻 址 和 数据 寻 址 。 寻 找 下 一 条 将 要 执行 的 指令 地 址 称 为 指令 寻 址 ， 
寻找 操作 数 的 地 址 称 为 数据 寻 址 。 指 令 寻 址 比较 简单 , 它 又 可 以 细 分 为 顺序 寻 址 和 跳跃 寻 
址 。 而 数据 寻 址 方式 种 类 较 多 ,其 最 终 目 的 都 是 寻找 所 需要 的 操作 数 。 

顺序 寻 址 可 通过 程序 计数 器 加 1, 自动 形 成 下 一 条 指令 的 地 址 ;跳跃 寻 址 则 需要 通过 程 
序 转移 类 指令 实现 。 

跳跃 寻 址 的 转移 地 址 形成 方式 有 3 种 : 直接 (绝对 ) 、 相 对 和 间接 寻 址 , 它 与 下 面 介绍 的 
数据 寻 址 方式 中 的 直接 、 相 对 和 间接 寻 址 是 相同 的 ,只 不 过 寻找 到 的 不 是 操作 数 的 有 效 地 址 
而 是 转移 的 有 效 地 址 。 


加 EE 
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3.2.3 基本 的 数据 寻 址 方式 


数据 寻 址 方式 是 根据 指令 中 给 出 的 地 址 码 字 段 寻 找 真 实 操作 数 地 址 的 方式 。 一 般 情况 
下 , 巾 于 指令 长 度 的 限制 ,指令 中 的 地 址 码 不 会 很 长 ,而 主 存 的 容量 却 可 能 越 来 越 大 。 以 
IBM PC/XT 机 为 例 , 主 存 容 量 可 达 1MB ,而 指令 中 的 地 址 码 字 段 最 长 仅 16 位 , 仅 能 直接 访 
问 主 存 的 一 小 部 分 ,而 无 法 访问 整个 主 存 空 间 。 就 是 在 字 长 很 长 的 大 型 机 中 ,即使 指令 中 能 
够 拿 出 足够 的 位 数 来 作为 访问 整个 主 存 空间 的 地 址 ,为 了 灵活 方便 地 编制 程序 ,也 需要 对 地 
址 进行 必要 的 变换 。 指 令 中 地 址 码 字 段 给 出 的 地 址 称 为 形式 地 址 (用 字母 A 表示 ), 这 个 地 
址 有 可 能 不 能 直接 用 来 访问 主 存 。 形 式 地 址 经 过 某 种 运算 而 得 到 的 能 够 直接 访问 主 存 的 地 
址 称 为 有 效 地 址 (用 字母 EA 表示 )。 从 形式 地 址 生成 有 效 地 址 的 各 种 方式 称 为 寻 址 方 
式 , 即 : 


指令 中 的 形式 地 址 -一半 有 效 地 址 


每 种 计算 机 的 指令 系统 都 有 上 自己 的 一 套数 据 寻 址 方式 ,不 同 计算 机 的 寻 址 方式 的 名 称 
和 含义 并 不 统一 ,下 面 介绍 大 多 数 计算 机 常用 的 几 种 基本 寻 址 方式 。 


1. 立即 寻 址 


立即 寻 址 是 一 种 特殊 的 寻 址 方式 ,指令 中 在 操作 码 字 段 后 面 的 部 分 不 是 通常 意义 上 的 
操作 数 地 址 ,而 是 操作 数 本 号 。 也 就 是 说 ,数据 就 包含 在 指令 中 ,只 要 取出 指令 ,也 就 取出 了 
可 以 立即 使 用 的 操作 数 , 这 样 的 数 称 为 立即 数 ,其 指令 格式 为 : 


ET 


这 种 方式 的 特点 是 : 在 取 指 令 时 ,操作 码 和 操作 数 被 同时 取出 ,不 必 上 再 次 访问 主 存 ,从 
而 提高 了 指令 的 执行 速度 。 但 是 ,因为 操作 数 是 指令 的 一 部 分 ,不 能 被 修改 ,而 且 立 即 数 的 
大 小 受到 指令 长 度 的 限制 ,所 以 这 种 寻 址 方式 灵活 性 最 差 ,通常 用 于 给 某 一 寄存 需 或 主 存单 
元 赋 初 值 或 提供 一 个 常数 。 

2. 寄存 器 寻 址 


寄存 天 寻 址 指令 的 地 址 码 部 分 给 出 茶 一 个 通用 寄存 硕 的 编号 Ri ,这 个 指定 的 寄存 天 中 


存放 着 操作 数 。 寄 存 器 寻 址 过 程 如 图 3-3 所 示 , 图 中 
的 IR 表示 指令 寄存 器 , 它 的 内 容 是 从 主 存 中 取出 的 下 Lo | R 
指令 。 操 作 数 S 与 寄存 器 R, 的 关系 为 ， 


R 


Malm 
这 种 寻 址 方式 具有 两 个 明显 的 优点 : 3-3 寄存 咒 寻 址 过 程 


J 从 寄存 副 中 存 取 数据 比 从 主 存 中 存 取 快 得 多 。 

G@ 由 于 寄存 副 的 数量 较 少 ,其 地 址 码 字 段 比 主 存单 元 地 址 字段 短 得 多 。 

这 种 方式 可 以 缩短 指令 长 度 , 提 高 指令 的 执行 速度 ,几乎 所 有 的 计算 机 者 使 用 了 寄存 天 
寻 址 方式 。 


3. 直接 寻 址 


指令 中 地 址 码 字 段 给 出 的 地 址 A 就 是 操作 数 的 有 效 地 址 , 即 形式 地 址 等 于 有 效 地 址 : 
EA 二 A。 由 于 这 样 给 出 的 操作 数 地 址 是 不 能 修改 的 ,与 程序 本 号 所 在 的 位 置 无 关 , 所 以 又 
称 为 绝对 寻 址 方式 。 图 3-4 所 示 为 直接 寻 址 的 示意 图 。 操 作 数 S 与 地 址 码 A 的 关系 为 : 
S=(A) 
主 存储 器 


OP | 直接 地 址 | 


3-4 直接 寻 址 过 程 


这 种 寻 址 方式 不 需 做 任何 寻 址 运算 ,简单 直观 ,也 便于 硬件 实现 ,但 地 址 空间 受到 指令 
中 地 址 码 字段 位 数 的 限制 。 


4. 间接 寻 址 


间接 寻 址 意味 着 指令 中 给 出 的 地 址 A 不 是 操作 数 的 地 址 ,而 是 存放 操作 数 地 址 的 主 存 
单元 的 地 址 ,简称 操作 数 地 址 的 地 址 。 通 常 在 指令 格式 中 划 出 一 位 作为 直接 或 间接 寻 址 的 
标志 位 ,间接 寻 址 时 标志 位 @=1。 

间接 寻 址 中 又 有 一 级 间接 寻 址 和 多 级 间接 寻 址 之 分 。 在 一 级 间接 寻 址 中 ,首先 按 指令 
的 地 址 码 字 段 先 从 主 存 中 取出 操作 数 的 有 效 地 址 , 即 EA=(A) ,然后 再 按 此 有 效 地 址 从 主 
存 中 读 出 操作 数 , 如 图 3-5(a) 所 示 。 操 作 数 S 与 地 址 码 A 的 关系 为 : 

S=((A)) 


存储 需 主 存储 天 
ER 
操作 数 


上 


IR 


有 效 地 址 
I 


操作 数 


(a) (b) 
3-5 “间接 寻 址 过 程 
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多 级 间接 寻 址 为 取得 操作 数 需 要 多 次 访问 主 存 , 即 使 在 找到 操作 数 有 效 地 址 后 ,还 需 再 
访问 一 次 主 存 才 可 得 到 真正 的 操作 数 , 如 图 3-5(b) 所 示 。 对 于 多 级 间接 寻 址 来 说 ,在 寻 址 
过 程 中 所 访问 到 的 每 个 主 存 单元 的 内 容 中 都 应 设 有 一 个 间 址 标志 位 。 通 常 将 这 个 标志 放 在 
主 存单 元 的 最 高 位 。 当 该 位 为 1 时 ,表示 这 一 主 存单 元 中 仍然 是 间接 地 址 ,需要 继续 间接 寻 
址 ; 当 该 位 为 0 时 ,表示 已 经 找到 了 有 效 地 址 ,根据 这 个 地 址 可 以 读 出 真正 的 操作 数 。 

间接 寻 址 要 比 直 接 寻 址 灵活 得 多 , 它 的 主要 优点 如 下 : 

QD 扩大 了 寻 址 范围 ,可 用 指令 中 的 短 地 址 访问 大 的 主 存 空 间 。 

@ 可 将 主 存单 元 作为 程序 的 地 址 指针 ,用 以 指示 操作 数 在 主 存 中 的 位 置 。 当 操作 数 的 
地 址 需要 改变 时 ,不 必修 改 指令 ,只 须 修改 存放 有 效 地 址 的 那个 主 存单 元 的 内 容 即 可 。 

但 是 ,间接 寻 址 在 取 指 之 后 至 少 需 要 两 次 访问 主 存 才能 取出 操作 数 , 降 低 了 取 操 作 数 的 
速度 。 尤 其 是 在 多 级 间接 寻 址 时 ,寻找 操作 数 要 花费 相当 多 的 时 间 , 甚 至 可 能 发 生 间 址 
循环 。 

5. 寄存 器 间接 寻 址 

为 了 克服 间接 寻 址 中 访 存 次 数 多 的 缺点 ,可 采用 寄存 右 间 接 寻 址 , 即 指令 中 的 地 址 码 给 
出 某 一 通用 寄存 器 的 编号 ,在 被 指定 的 寄存 器 中 存放 操作 数 的 有 效 地 址 ,而 操作 数 则 存放 在 


主 存单 元 中 ,其 寻 址 过 程 如 图 3-6 所 示 。 操 作 数 S 与 寄存 器 号 R; 的 关系 为 : 
一 人 有 


这 种 寻 址 方式 的 指令 较 短 ,并且 在 取 指 后 只 须 一 次 访 存 便 可 得 到 操作 数 ,因此 指令 执行 
速度 较 间接 寻 址 方式 快 ,是 一 种 使 用 广泛 的 寻 址 方式 。 
6. 变 址 寻 址 


变 址 寻 址 就 是 把 变 址 寄存 副 R: 的 内 容 与 指令 中 给 出 的 形式 地 址 A 相 加 ,形成 操作 数 
有 效 地 址 , 即 EA 二 (R,) 十 A。R 的 内 容 称 为 变 址 值 ,其 寻 址 过 程 如 图 3-7 所 示 。 操 作 数 S 
与 地 址 码 和 变 址 寄存 硕 的 关系 为 : 
S 一 ((R-.) 十 人 A) 


主 和 仓储 徊 
主 存储 大 


CR 
操作 数 


图 3-6 寄存 器 间接 寻 址 过 程 图 3-7 变 址 寻 址 过 程 


变 址 寻 址 是 一 种 广泛 采用 的 寻 址 方式 ,最 典型 的 用 法 是 将 指令 中 的 形式 地 址 作为 基准 
地 址 ,而 变 址 寄存 右 的 内 容 作为 修改 量 。 在 遇 到 需要 频繁 修改 地 址 时 ,无 须 修改 指令 ,只 要 
修改 变 址 值 就 可 以 了 ,这 对 于 数组 运算 .字符 串 操 作 等 成 批 数据 处 理 是 很 有 用 的 。 例 如 ,要 


把 一 组 连续 存放 在 主 存单 元 中 的 数据 ( 首 地 址 是 A) 依 次 传送 到 另 一 存储 区 ( 首 地 址 为 B) 
中 , 则 只 须 在 指令 中 指明 两 个 存储 区 的 首 地 址 A 和 B( 形 式 地 址 ) ,用 同一 变 址 寄存 器 提供 
修改 量 K, 即 可 实现 (A 十 K) 一 B 十 K。 变 址 寄存 器 的 内 容 在 每 次 传送 之 后 自动 地 修改 。 

在 具有 变 址 寻 址 的 指令 中 ,除去 操作 码 和 形式 地 址 外 ,还 应 具有 变 址 寻 址 标志 , 当 有 多 
个 变 址 寄存 器 时 ,还 必须 指明 具体 寻找 哪 一 个 变 址 寄存 器 。 


7. 基 址 寻 址 
基 址 寻 址 是 将 基 址 寄存 需 Rs 的 内 容 与 指令 中 给 出 的 位 移 量 D 相 加 ,形成 操作 数 有 效 
地 址 , 即 EA 二 (Rs) 十 D。 基 址 寄存 胡 的 内 容 称 为 基 址 值 。 指 令 的 地 址 码 字 段 是 一 个 位 移 


量 , 位 移 量 可 正 、 可 人 负 , 如 图 3-8 所 示 。 操 作 数 S 与 基 址 寄存 器 和 地 址 码 的 关系 为 : 
S=((R,)+D) 


[ma [一 


3-8 基 址 寻 址 过 程 


基 址 寻 址 原 是 大 型 计算 机 采用 的 一 种 技术 ,用 来 将 用 户 的 逻辑 地 址 (用 户 编程 时 使 用 的 
地 址 ?转化 成 主 存 的 物理 地 址 (程序 在 主 存 中 的 实际 地 址 )。 

基 址 寻 址 和 变 址 寻 址 在 形成 有 效 地 址 时 所 用 的 算法 是 相同 的 ,而 且 在 一 些 计算 机 中 ,这 
两 种 寻 址 方式 都 是 由 同样 的 人 硬件 来 实现 的 。 但 是 ,它们 两 者 实际 上 是 有 区 别 的 。 一 般 来 说 ， 
变 址 寻 址 中 变 址 寄存 带 提 供 修改 量 ( 可 变 的 ) ,而 指令 中 提供 基准 值 (固定 的 ); 基 址 寻 址 中 基 
址 寄存 器 提供 基准 值 ( 固 定 的 ) ,而 指令 中 提供 位 移 量 (可 变 的 )。 这 两 种 寻 址 方式 应 用 的 场 
合 也 不 同 , 变 址 寻 址 是 面 加 用户 的 ,用 于 访问 字符 串 、 回 量 和 数组 等 成 批 数据 ;而 基 址 寻 址 面 
问 系 统 ,主要 用 于 逻辑 地 址 和 物理 地 址 的 变换 ,用 以 解决 程序 在 主 存 中 的 再 定位 和 扩大 寻 址 
空间 等 问题 。 在 菜 些 大 型 机 中 , 基 址 寄存 船只 能 由 特权 指令 来 管理 ,用 户 指令 无 权 操 作 和 修 
改 。 在 某 些 小 、 微 型 计算 机 中 , 基 址 寻 址 和 变 址 寻 址 实际 上 是 合 二 为 一 的 。 


8. 相对 寻 址 


相对 寻 址 是 基 址 寻 址 的 一 种 变通 ,由 程序 计数 需 (PC) 提 供 基 准 地 址 ,指令 中 的 地 址 码 
字段 作为 位 移 量 D, 两 者 相 加 后 得 到 操作 数 的 有 效 地 址 , 即 EA 二 (PC) 十 D。 位 移 量 指 出 的 
是 操作 数 和 现行 指令 之 间 的 相对 位 置 , 如 图 3-9 所 示 。 

这 种 寻 址 方式 有 如 下 两 个 特点 : 

J 操作 数 的 地 址 不 是 固定 的 , 它 随 着 PC 值 的 变化 而 变化 ,并 且 与 


指令 地 址 之 间 总 是 相 
差 一 个 固定 值 。 当 指令 地 址 变换 时 ,由 于 其 位 移 量 不 变 , 使 得 操作 数 与 指 


地 
在 可 用 的 存储 区 
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3-9 相对 寻 址 过 程 


PG 


内 一 起 移动 ,所 以 仍 能 保证 程序 的 正确 执行 。 采 用 PC 相对 寻 址 方式 编写 的 程序 可 在 主 存 
中 任意 浮动 , 它 放 在 主 存 的 任何 地 方 所 执行 的 效果 都 是 一 样 的 。 

G@ 对 于 指令 地 址 而 言 ,操作 数 地 址 可 能 在 指令 地 址 之 前 或 之 后 ,因此 指令 中 给 出 的 位 
移 量 可 负 \ 可 正 , 通 常用 补 码 表示 。 如 果 位 移 量 为 nn 位, 则 相对 寻 址 的 寻 址 范围 为 : 

CPOI— 2 CPU 一】 

注意 : 有 些 计 算 机 是 以 当前 指令 地 址 为 基准 的 ,有 些 计 算 机 是 以 下 一 条 指令 地 址 为 基 
准 的 。 这 是 因为 有 的 机 器 是 在 当前 指令 执行 完 时 , 才 将 PC 的 内 容 加 1( 或 加 增 量 ); 而 有 的 
机 器 是 在 取出 当前 指令 后 立即 将 PC 的 内 容 加 1( 或 加 增 量 ) ,使 之 变 成 下 一 条 指令 的 地 址 。 
后 一 种 方法 将 使 位 移 量 的 计算 变 得 比较 复杂 ,特别 是 对 于 变 字 长 指令 更 加 麻烦 。 不 过 在 实 
际 应 用 时 ,位 移 量 是 由 汇编 程序 自动 形成 的 ,程序 员 并 不 需要 特别 关注 。 


9. 页 面 寻 址 


页 面 寻 址 相当 于 将 整个 主 存 空间 分 成 寿 干 个 大 小 相同 的 区 ,每 个 区 称 为 一 We 
干 个 主 存单 元 。 例 如 ,1 个 64KB 的 存储 需 被 划分 为 256 个 页 面 ,每 个 页 面 中 有 256 个 字 
如 图 3-10(a) 所 示 。 每 页 都 有 上 自己 的 编号 , 称 为 页 面 地 址 ;页 面 内 的 每 个 主 存 单元 也 有 己 
的 编号 , 称 为 页 内 地 址 。 这 样 ,存储 器 的 有 效 地 址 就 被 分 为 两 部 分 : 前 部 为 页 面 地 址 (在 此 
例 中 占 8 位 ) ,后 部 为 页 内 地 址 (也 占 8 位 )。 页 内 地 址 巾 指令 的 地 址 码 部 分 自动 直接 提供 ， 
它 与 页 面 地 址 通过 简单 的 拼装 连接 就 可 得 到 有 效 地 址 ,无 须 进行 计算 ,因此 寻 址 了 迅速。 根据 
页 面 地 址 的 来 源 不 同 , 页 面 寻 址 又 可 以 分 成 以 下 3 种 不 同 的 方式 。 

基 页 寻 址 。 基 页 地 址 又 称 零 页 寻 址 。 巾 于 页 面 地 址 全 等 于 0, 所 以 有 效 地 址 EA= 
0VA(CV 在 这 里 表示 简单 拼接 ) ,操作 数 S 在 零 页 面 中 ,如 图 3-10(b) 所 示 。 基 页 寻 址 实际 上 
就 是 直接 寻 址 。 

@ 当前 页 寻 址 。 页 面 地 址 就 等 于 程序 计数 器 (PC) 的 高 位 部 分 的 内 容 , 所 以 有 效 地 址 
EA 二 (PC)n/ A, 操作 数 S 与 指令 本 身 处 于 同一 页 面 中 ,如 图 3-10(c) 所 示 。 

(3 页 寄存 右 寻 址 。 页 面 地 址 取 自 页 寄存 器 ,与 形式 地 址 相 拼 接 形 成 有 效 地 址 ,如 
图 3-10(d) 所 示 。 

前 两 种 方式 因 不 需要 页 寄存 器 ,所 以 用 得 较 多 些 。 有 些 计 算 机 在 指令 格式 中 设置 了 一 
个 页 面 标志 位 (Z/C)。Z/C=0, 表 示 0 页 寻 址 ;Z/C=1, 表 示 当 前 页 寻 址 。 

怎样 才能 知道 一 条 指令 所 采用 的 是 什么 寻 址 方式 呢 ? 为 了 能 区 分 出 各 种 不 同 的 寻 址 方 
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(a) (d) 
图 3-10 ”页 面 寻 址 


式 ,必须 在 指令 中 给 出 标识 。 标 识 的 方式 通常 有 两 种 : 显 式 和 隐 式 。 显 式 的 方法 就 是 在 指 

令 中 设置 专门 的 寻 址 方式 字段 ,用 二 进 制 编码 来 

表明 寻 址 方式 类 型 ,如 图 3-11(a) 所 示 ; 隐 式 的 方 

式 是 由 指令 的 操作 码 字 段 说 明 指 令 格式 并 隐 含 约 9 

定 寻 址 方式 ,如 图 3-11(b) 所 示 。 
注意 : 一 条 指令 若 有 两 个 或 两 个 以 上 的 地 址 本 

码 时 ,各 地 址 码 可 采用 不 同 的 寻 址 方式 。 例 如 , 源 由 操作 码 隐 含 指出 寻 址 方式 

地 址 采用 一 种 寻 址 方式 ,而 目的 地 址 采用 另 一 种 0) 

寻 址 方式 。 图 3-11 指令 中 寻 址 方式 的 表示 


3.2.4 变型 或 组 合 寻 址 方式 


前 面 介绍 了 9 种 稼 用 的 基本 寻 址 方式 ,其 他 的 寻 址 方式 则 是 这 9 种 寻 址 方式 的 变型 或 
组 合 。 


1. 自 增 型 寄存 器 间 址 和 自 减 型 寄存 器 间 址 


这 两 种 寻 址 方式 实际 上 都 是 寄存 器 间 接 寻 址 方式 的 变型 ,通用 寄存 器 在 这 里 作为 自动 
变 址 寄存 需 。 

(1) 目 增 寻 址 

在 自 增 寻 址 时 ,寄存 器 R; 的 内 容 是 有 效 地 址 ,按照 这 个 有 效 地 址 从 主 存 中 取 数 以 后 , 寄 
存 需 的 内 容 目 动 增 量 修改 。 在 字 节 编 址 的 计算 机 中 ,各 指 癌 下 一 个 字 贡 ,寄存 硕 的 内 容 加 
1; 若 指向 下 一 个 字 ( 假 设 字 长 16 位 ) ,寄存 器 的 内 容 加 2, 如 图 3-12(a) 所 示 。 

寻 址 操作 的 含义 为 : EA 二 (R;),R; 一 (R;) 十 d。 其 中 ,EA 为 有 效 地 址 ,d 为 修改 量 , 通 
常 记 作 (R;) 十 ,加 号 在 括号 之 后 ,形象 地 表示 先 操 作 后 修改 。 
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(2) 目 减 寻 址 
自 减 寻 址 是 先 对 寄存 器 R; 的 内 容 自 动 减 量 修改 ( 减 1 或 减 2) ,修改 之 后 的 内 容 才 是 
操作 数 的 有 效 地 址 , 据 此 可 到 主 存 中 取出 操作 数 。 图 3-12(b) 给 出 了 自 减 寻 址 过 程 示 


意图 。 


主 和 存储 胡 


Wn 


(a) (b) 
图 3-12 自 增 / 自 减 寻 址 方式 


寻 址 操作 的 含义 为 : Ri 一 (R;) 一 d,EA 王 (R;) ,通常 记 作 一 (R;), 减 号 在 括号 之 前 ,形象 
地 表示 先 修 改 后 操作 。 上 月 减 寻 址 和 上 自 增 寻 址 一 起 ,可 以 使 任何 一 个 寄存 大 作为 堆栈 指针 。 

采用 自 增 / 减 寻 址 最 灵活 的 当 属 MC68000 机 , 它 上 具有 字 节 、 字 、 双 字 的 自动 增 / 减 寻 址 
方式 。 


2. 扩展 变 址 方式 


把 变 址 和 间 址 两 种 寻 址 方式 结合 起 来 就 成 为 扩展 变 址 方式 , 按 寻 址 方式 操作 的 先后 顺 
序 , 有 前 变 址 和 后 变 址 两 种 寻 址 方式 。 

(1) 先 变 址 后 间 址 (前 变 址 寻 址 方式 ) 

先进 行 变 址 运算 ,其 运算 结果 作为 间接 地 址 ,间接 地 址 指出 的 单元 的 内 容 才 是 有 效 地 
址 。 所 以 ,有 效 地 址 EA=(CR.) 十 A) ,操作 数 S$=((CR) 十 A))。 其 寻 址 过 程 如 图 3-13(a) 
所 示 。 


主 和 仓储 从 主 和 存储 售 
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(a) (b) 
3-13 ”前 /后 变 址 寻 址 方式 


(2) 先 间 址 后 变 址 (后 变 址 寻 址 方式 ) 

将 指令 中 的 地 址 码 先 进行 一 次 间接 寻 址 ,然后 再 与 变 址 值 进行 运算 ,从 而 得 到 一 个 有 效 
地 址 。 所 以 ,有 效 地 址 EA 二 (R; ) 十 (A) ,操作 数 S= (CR.) 十 (A))。 其 寻 址 过 程 如 图 3-13(b) 
所 示 。 


3. 基 址 变 址 寻 址 


基 址 变 址 寻 址 是 最 灵活 的 一 种 寻 址 方式 ,此 时 有 效 地 址 是 由 基 址 寄存 右 中 的 值 、 变 址 寄 
存 器 中 的 值 和 位 移 量 三 者 相 加 求 得 的 。 在 这 3 项 中 , 除 位 移 量 在 指令 一 旦 确定 后 就 不 能 再 
修改 以 外 , 基 址 和 变 址 寄存 需 中 的 内 容 都 可 以 改变 。 

EA=(R,) 十 (R.) 十 D 

其 中 ,Rs 为 基 址 寄存 器 ,R 为 变 址 寄存 器 ,D 为 位 移 量 。 

IBM 370 机 中 就 有 这 种 寻 址 方式 。 实 际 上 ,R， 和 R, 并 不 单独 存在 ,通常 借用 16 个 通 
用 寄存 器 中 的 15 个 (0 寄存 天 除外 ) 来 作为 Re 或 R:。 上 式 3 项 中 的 任何 一 项 都 可 以 缺 省 。 

基 址 变 址 寻 址 方式 在 Intel 80x86 中 是 最 基本 的 寻 址 方式 ,其 他 多 种 方式 可 由 它 派 生出 
来 。 基 址 寄存 器 (BX 或 BP)、 变 址 寄存 器 (SI 或 DD 及 位 移 量 都 可 以 缺 省 ,位 移 量 允许 是 8 
位 或 16 位 的 带 符号 数 。 


(BX)] [SD 
EA= 
| (BP) | | (DD 


| + 位 移 有 


3.3 堆栈 与 堆栈 操作 


堆栈 是 一 种 按 特 定 顺 序 进 行 存 取 的 存储 区 ,这 种 特定 顺序 可 归结 为 “后 进 先 出 (LIFO)” 
或 “先进 后 出 (FILO)”。 在 一 般 计 算 机 中 ,堆栈 主要 用 来 暂 存 中 断 断 点 、 子 程序 调用 时 的 返 
回 地 址 ,状态 标志 及 现场 信息 等 ,也 可 用 于 子 程序 调用 时 参数 的 传递 。 


3.3.1 堆栈 结构 


堆栈 区 通 背 是 主人 存储 融 中 指定 的 一 个 区 域 , 也 可 以 专门 设置 一 个 小 而 快 的 存储 天 作为 
堆栈 区 。 在 堆栈 容量 很 小 的 情况 下 ,还 可 以 用 一 组 寄存 天 来 构成 堆栈 。 


1. 寄存 器 堆栈 


有 些 计算 机 中 用 一 组 专门 的 寄存 需 构 成 寄存 硕 扒 栈 , 又 称 为 便 堆 栈 。 这 种 堆栈 的 栈 顶 
是 固定 的 ,寄存 硕 组 中 各 寄存 需 是 相互 连接 的 ,它们 之 间 具 有 对 应 位 上 自动 推移 的 功能 , 即 可 
将 一 个 寄存 硕 的 内 容 推 移 到 相 邻 的 另 一 个 寄存 部 中 ,如 图 3-14 所 示 。 在 执行 压 入 操作 ( 进 
栈 ) 时 ,一 个 压 入 信号 将 使 所 有 寄存 器 的 内 容 依 次 问 下 推移 一 个 位 置 , 即 寄存 右 i 的 内 容 被 
传送 到 i 十 1, 同 时 一 个 位 的 数据 被 压 入 栈 顶 (寄存 器 0)。 在 执行 弹出 操作 (出 栈 ) 时 ,一 个 
弹出 信号 将 把 所 有 寄存 硕 的 内 容 依次 问 上 推移 一 个 位 置 , 即 寄存 需 守 的 内 容 被 传送 到 寄存 
器 i 一 1 , 栈 顶 (寄存 器 0) 的 内 容 被 弹出 。 

从 图 3-14 可 看 出 ,上 述 堆栈 中 最 多 只 能 压 和 信 上 个 数据 ,否则 将 丢失 信息 。 这 种 堆栈 的 
工作 过 程 很 像 子 弹 夹 的 弹 仓 , 由 于 栈 顶 位 置 固 定 , 故 不 必 设 置 堆 栈 的 栈 项 指针 。 


ER 
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| 


3-14 寄存 器 堆栈 结构 


2. 存储 器 堆栈 


寄存 器 堆栈 的 成 本 比较 高 ,不 适 于 作 大 容量 的 堆栈 ,而 从 主 存 中 划 出 一 段 区 域 来 作为 堆 
栈 是 最 合算 旦 最 常用 的 方法 。 这 种 堆栈 又 称 为 软 堆栈 ,堆栈 的 大 小 可 变 , 栈 底 固 定 , 栈 顶 浮 
动 , 故 需要 一 个 专门 的 人 硬件 寄存 器 作为 堆栈 栈 顶 指针 ,简称 栈 指 针 (SP)。 栈 指针 所 指定 的 
存储 单元 就 是 堆栈 的 栈 顶 。 存 储 需 堆栈 又 可 分 为 两 种 : 自 底 向 上 生成 堆栈 和 上 自 顶 回 下 生成 
堆栈 。 假 设 栈 指针 始终 指向 栈 顶 的 满 单元 , 且 压 人 和 弹出 的 数据 为 一 个 字 节 。 

(1) 和 目 底 向 上 生成 (加 低地 址 方向 生成 ) 堆 栈 

这 种 堆栈 的 栈 底 地 址 大 于 栈 顶 地 址 ,如 图 3-15 所 示 。 因 此 , 进 栈 时 ,堆栈 指针 SP 的 内 
容 需 要 先 自 动 减 1, 然 后 再 将 数据 压 入 堆栈 ;出 栈 时 ,需要 先 将 


堆栈 中 的 数据 弹出 ,然后 SP 的 内 容 再 自动 加 1。 进 、 出 栈 的 过 i 
程 可 描述 如 下 。 栈 
进 栈 : 区 
(SP) 一 1>SP “; 修 改 栈 指针 高 地 址 
(A) 一 (SP) ;将 A 中 的 内 容 压 人 栈 项 单元 3-15 存储 器 堆栈 结构 
出 栈 : 
((SP))—>A ;将 栈 顶 单元 内 容 弹 出 送 入 A 中 


(SP) 十 1 一 SP ;修改 栈 指针 


其 中 ,A 为 寄存 器 或 主 存单 元 地 址 ; (SP) 表 示 堆 栈 指 针 的 内 容 , 即 栈 顶 单元 地 址 ;((SP)) 表 
示 栈 顶 单 元 的 内 容 。 

(2) 自 顶 癌 下 生成 (向 高 地 址 方向 生成 ) 堆 栈 

这 种 堆栈 与 自 底 向 上 堆栈 正好 相反 , 它 的 栈 底 地 址 小 于 栈 顶 地 址 。 进 栈 时 , 先 令 (SP) 十 1 
SP, 然 后 再 压 人 数据 ;出 栈 时 , 先 将 数据 弹出 ,然后 (SP) 一 1-~SP。 

软 堆栈 的 容量 可 以 很 大 ,而 且 可 以 在 整个 主 存 中 浮动 ,但 是 速度 比较 慢 , 每 访问 一 次 堆 
栈 实 际 就 是 访问 一 次 主 存 。 在 一 些 大 型 的 计算 机 系统 中 ,希望 堆栈 的 容量 大 、 速 度 快 , 故 将 


前 述 两 种 堆栈 组 合 起 来 构成 软 \ 便 结合 的 堆栈 。 在 这 样 的 堆栈 中 ,一 般 压 入 、 弹 出 操作 在 小 
容量 的 刹 堆 栈 中 进行 ,这 样 可 保证 访问 速度 快 。 当 便 堆 栈 已 满 之 后 ,每 器 鲁 堆 栈 压 入 一 个 数 
据 , 总 是 将 其 栈 底 寄存 融 中 的 数据 压 入 软 堆栈 中 ,使 堆栈 总 容量 有 效 扩 大 ;同样 ,数据 出 栈 
时 ,不 断 将 软 堆栈 中 栈 顶 的 内 容 上 移 至 便 堆栈 的 栈 抵 寄存 副 中 。 显 然 它 集中 了 便 堆栈 速度 
快 、 软 堆栈 容量 大 的 优点 ,只 是 在 控制 上 稍 复杂 些 , 但 这 是 完全 可 以 实现 的 。 


3.3.2 堆栈 操作 


堆栈 操作 既 不 是 在 堆栈 中 移动 它 所 存储 的 内 容 , 也 不 是 把 已 存储 在 栈 中 的 内 容 从 栈 中 
抹 近 ,而 是 通过 调整 堆栈 指针 而 给 出 新 的 栈 顶 位 置 ,以 便 对 位 于 栈 顶 位 置 的 数据 进行 操作 。 

在 一 般 计 算 机 中 ,堆栈 主要 用 来 暂 存 中 断 断 点 、 子 程序 调用 时 的 返回 地 址 .状态 标志 及 
现场 信息 等 ,也 可 用 于 子 程序 调用 时 参数 的 传递 ,所 以 用 于 访问 堆栈 的 指令 只 有 进 栈 ( 压 入 ) 
和 出 栈 ( 弹 出 ) 两 种 。 

在 堆栈 计算 机 (如 HP-3000 和 B5000 机 等 ) 中 ,算术 逻辑 类 指令 中 没有 地 址 码 字 段 , 故 
称 为 零 地 址 指令 。 参 加 运算 的 两 个 操作 数 隐 含 地 从 堆栈 顶部 弹出 , 送 到 运算 器 中 进行 运算 ， 
运算 的 结果 再 隐 含 地 压 人 堆栈 。 如 果 将 算术 表达 式 改 写 为 逆 波 兰 表 达 式 ,用 零 地 址 指令 进 
行 运算 是 十 分 方便 的 。 例 如 ,有 算术 表达 式 aX6b 十 c 二 d, 运 算 结 果 送 给 X, 这 个 算术 表达 式 
可 以 用 逆 波 兰 法 表示 为 cgXcd 二 十 。 现 在 用 零 地 址 指令 和 一 地 址 指令 对 该 算式 编程 ,并 利 
用 堆栈 完成 运算 。 假 设 堆栈 采用 自 底 向 上 生成 方式 ,用 大 写字 母 A 表示 数据 a 的 地 址 ,其 
他 依次 类 推 , 其 程序 段 为 : 


PUSH A ;数据 a 压 人 堆栈 
PUSH B ;数据 b 压 入 堆栈 
MUL ;完成 aXb 

PUSH C ;数据 c 压 入 堆栈 
PUSH D ;数据 d 压 入 堆栈 
DIV ;完成 c 二 d 

ADD ;完成 aXb 十 c 二 d 
POP X ;结果 存 人 X 单元 


注意 : 执行 一 条 零 地 址 的 双 操 作 数 运算 指令 ,如 果 是 软 堆栈 , 则 需要 访问 4 次 主 存 ;如 
果 是 硬 堆 栈 , 则 只 需要 访问 一 次 主 存 。 


3.4 指令 类 型 
一 台 计 算 机 的 指令 系统 可 以 有 上 百 条 指令 ,这些 指 令 按 其 功能 可 以 分 成 几 种 类 型 ,下面 
分 别 介绍 。 


3.4.1 数据 传送 类 指令 


数据 传送 类 指令 是 最 基本 的 指令 类 型 ,主要 用 于 实现 寄存 天 与 寄存 天 之 间 、 寄 存 关 与 主 
存单 元 之 间 以 及 两 个 主 存单 元 之 间 的 数据 传送 。 数 据 传送 类 指令 又 可 以 细 分 为 下 列 几 种 。 


EE 
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1. 一 般 传送 指令 


一 般 传送 指令 具有 数据 复制 的 性 质 , 即 数据 从 源 地 址 传送 到 目的 地 址 ,而 源 地 址 中 的 内 
容 保持 不 变 。 一 般 传 送 类 指令 常用 助 记 符 MOV 表示 ,根据 数据 传送 的 源 和 目的 的 不 同 , 又 
可 分 为 以 下 几 种 传递 方式 : 

J 主 存 单元 之 间 的 传送 。 

@ 从 主 存单 元 传送 到 寄存 大。 在 有 些 计 算 机 中 ,该 指令 用 助 记 符 LOAD( 取 数 指令 ) 
表示 。 

@) 从 寄存 硕 传 送 到 主 存单 元 。 在 有 些 计 算 机 里 ,该 指令 用 助 记 符 STORE( 存 数 指令 ) 
表示 。 

网 椅 存 天 之 间 的 传送 。 


2. 堆栈 操作 指令 


堆栈 指令 实际 上 是 一 种 特殊 的 数据 传送 指令 ,分 为 进 栈 (PUSH) 和 出 栈 (POP) 两 种 ,在 
程序 中 它们 往往 是 成 对 出 现 的 。 
如 果 堆 栈 是 主 存 的 一 个 特定 区 域 ,那么 对 堆栈 的 操作 也 就 是 对 存储 器 的 操作 。 


3. 数据 交换 指令 


前 述 的 传送 痢 是 单方 同 的 。 然 而 ,数据 传送 也 可 以 是 双方 向 的 ,即将 源 操 作 数 与 目的 操 
作 数 (一 个 字 节 或 一 个 字 ) 相 互 交换 位 置 。 


3.4.2 运算 类 指令 
1. 算术 运算 类 指令 


算术 运算 指令 主要 用 于 定点 和 浮 点 运算 。 这 类 运算 包括 定点 加 、 减 、 乘 \ 除 指令 , 浮 点 
加 \ 减 、 乘 、 除 指令 以 及 加 1\ 减 1、 比较 等 ,有 些 机 器 还 有 十 进 制 算 术 运 算 指 令 。 

绝 大 多 数 算术 运算 指令 都 会 影响 到 状态 标志 位 , 通 稼 的 标志 位 有 进位 溢出 、 全 零 . 正 负 
和 奇偶 等 。 

为 了 实现 高 精度 的 加 减 运 算 ( 双 倍 字 长 或 多 字 长 ) ,低位 字 ( 字 节 ) 加 法 运算 所 产生 的 进 
位 (或 减法 运算 所 产生 的 借 位 ) 都 存放 在 进位 标志 中 ;在 高 位 字 ( 字 节 ) 加 减 运算 时 ,应 考虑 低 
位 字 ( 字 节 ) 的 进位 (或 依 位 ) ,因此 ,指令 系统 中 除去 普通 的 加 、 减 指令 外 ,一般 都 设置 了 市 进 
位 加 指令 和 带 借 位 减 指令 。 

2. 逻辑 运算 类 指令 

一 般 计 算 机 都 具有 与 ,或 . 非 和 异 或 等 逻辑 运算 指令 。 这 类 指令 在 没有 设置 专门 的 位 操 
作 指 令 的 计算 机 中 常用 于 对 数据 字 ( 字 节 ) 中 某 些 位 (一 位 或 多 位 ) 进 行 操 作 , 和 常见 的 应 用 
如 下 。 

(1) 按 位 测 ( 位 检查 ) 

利用 “与 ”指令 可 以 屏蔽 掉 数 据 字 ( 字 节 ) 中 的 某 些 位 。 通 常 让 被 检查 数 作 为 目的 操作 


数 , 屏 蔽 字 作 为 源 操作 数 , 要 检测 某 些 位 ,可 使 屏蔽 字 的 相应 位 为 "1”, 其 余 位 为 "0”, 然 后 执 
行 “ 与 ”指令 , 则 可 取出 所 要 检查 的 位 来 。 

(2) 按 位 清 ( 位 清除 ) 

利用 “与 ”指令 还 可 以 使 目的 操作 数 的 某 些 位 置 “0”。 只 要 源 操作 数 的 相应 位 为 “0”, 其 
余 位 为 "1”, 然 后 执行 “与 ?指令 即 可 。 

(3) 按 位 置 ( 位 设置 ) 

利用 “或 ”指令 可 以 使 目的 操作 数 的 某 些 位 置 “1”。 只 要 源 操作 数 的 相应 位 为 “1”, 其余 
位 为 “0”, 然 后 执行 “或 ”指令 即 可 。 

(4) 按 位 修改 

利用 “ 异 或 ”指令 可 以 修改 目的 操作 数 的 某 些 位 ,只 要 源 操作 数 的 相应 位 为 “1”, 其 余 位 
为 “0”,“ 异 或 ”之 后 就 达到 了 修改 这 些 位 的 目的 (因为 AB1=A,A 吕 0=A)。 

(5) 判 符合 

若 两 数 相符 合 , 其 “ 异 或 ”之 后 的 结果 必定 为 全 “0”。 


3. 移 位 类 指令 


移 位 指令 分 为 算术 移 位 .逻辑 移 位 和 循环 移 位 3 类 ,它们 又 可 分 为 左 移 和 右 移 两 种 。 
(1) 算术 移 位 
算术 移 位 的 对 象 是 带 符号 数 , 在 移 位 过 程 中 


必须 保持 操作 数 的 符号 不 变 。 当 左 移 一 位 时 ,如 大柳 操作 数 


[ch 天- 和 | 一 
不 产生 溢出 , 则 数值 乘 以 2; 而 右 移 一 位 时 ,如 不 
考虑 因 移出 舍 去 的 未 位 尾数 , 则 数值 除 以 2, 如 ”从 ， 
图 3-16(a) 有 所 示 。 (a) 
(2) 逻辑 移 位 操作 数 
逻辑 移 位 的 对 象 是 无 符号 数 , 因 此 移 位 时 不 ” 左 移 ， [ch 一 一 一 一 ~ 一 0 
必 考 虑 符号 问题 ,如 图 3-16(b) 所 示 。 从 图 中 可 操作 数 
以 看 出 ,逻辑 左 移 指令 和 算术 左 移 指令 移 位 操作 ty: [| “一 一 一 上 
过 程 完 全 相同 ,这 是 因为 正确 的 算术 左 移 ( 不 产生 (b) 
溢出 时 ) 与 逻辑 左 移 结果 相同 。 操作 数 
(3) 循环 移 位 A 二 == 
循环 移 位 按 是 否 与 进位 位 一 起 循环 又 分 为 两 操作 数 
种 ; 小 循环 (不 带 进位 循环 ) ,如 图 3-16(c) 所 示 ; ”< 侈 ~ 一 一 一 
大 循环 ( 带 进位 循环 ) ,如 图 3-16(d) 所 示 。 (9) 
3.4.3 程序 控制 类 指令 = 
程序 控制 类 指令 用 于 控制 程序 的 执行 顺序 ， 操作 数 
并 使 程序 具有 测试 .分 析 与 判断 的 能 力 。 因 此 , 它 。 圳 移 ; 
们 是 指令 系统 中 一 组 非常 重要 的 指令 ,主要 包括 (d) 


转移 指令 、 子 程序 调用 和 返回 指令 等 。 3-16 移 位 操作 过 程 


下 


计 径 机 组 成 原理 (第 4 版 ) 


1. 转移 指令 


在 程序 执行 过 程 中 ,通常 采用 转移 指令 来 改变 程序 的 执行 顺序 。 转 移 指 令 又 分 无 条 件 
转移 和 条 件 转 移 两 种 : 

无条件 转 移 又 称 必 转 , 它 在 执行 时 将 改变 程序 的 常规 执行 顺序 ,不 受 任何 条 件 的 约 
束 , 直 接 把 程序 转向 该 指令 指出 的 新 的 位 置 并 执行 ,其 助 记 符 一 般 为 JMP。 

色 条 件 转移 必须 受到 条 件 的 约束 ,各 满足 指令 所 规定 条 件 , 则 程序 转移 ;否则 ,程序 仍 
顺序 执行 。 条 件 转移 指令 主要 用 于 程序 的 分 文 , 当 程序 执行 到 某 处 时 ,要 在 两 个 分 文中 选择 
一 文 , 这 就 需要 根据 某 些 测试 条 件 做 出 判断 。 

无 论 是 条 件 转 移 还 是 无 条 件 转移 都 需要 给 出 转移 地 址 。 寿 采用 相对 寻 址 方式 , 则 转移 
地 址 为 当前 指令 地 址 ( 即 PC 的 值 ) 和 指令 中 给 出 的 位 移 量 之 和 , 即 (PC) 十 位 移 量 习 PC; 寿 
采用 绝对 寻 址 方式 , 则 转移 地 址 由 指令 的 地 址 码 字 有 段 直接 给 出 , 即 A 一 PC。 

条 件 转 移 指 令 采 用 相对 寻 址 方式 ,通常 位 移 量 只 有 一 个 字 节 ,这 样 转移 范围 只 能 在 离 当 
前 PC 的 一 128 一 十 127 个 字 节 之 内 ,在 32 位 的 80x86 中 ， ie se 此 时 
转移 范围 可 以 超出 原来 的 一 128 一 十 127。 

转移 的 条 件 以 某 些 标志 位 或 这 些 标志 位 的 逻辑 运算 作为 依据 ,根据 单个 标志 位 的 条 件 
转移 指令 的 转移 条 件 是 上 次 运算 结果 的 某 些 标志 ,如 进位 标志 、 结 果 为 零 标 志 、 结 果 洲 出 标 
志 等 ,而 用 于 无 符号 数 和 带 符号 数 的 条 件 转移 指令 的 转移 条 件 则 是 上 述 标志 位 逻辑 运算 的 
结果 。 

无 符号 数 之 间 大 小 比较 后 的 条 件 转移 指令 和 带 符 号 数 之 间 的 大 小 比较 后 的 条 件 转 移 指 
令 有 很 大 不 同 。 融 符号 数 间 的 次 序 关系 称 为 大 于 (G)、 等 于 (E) 和 小 于 (L); 无 符号 数 间 的 
次 序 关 系 称 为 高 于 (A) 、 等 于 (E) 和 低 于 (B) 。 


2. 子 程序 调用 指令 


子 程序 是 一 组 可 以 2 J 只 要 知道 子 程序 的 入 口 地 址 就 能 调用 它 。 通 常 把 
ee 完成 某 种 特定 功能 的 程序 单独 编 成 子 程序 ,在 需要 时 由 主 程序 

它们 ,这样 做 既 简 化 了 程序 设计 ,又 节省 了 存储 空间 。 

OT 
序 是 子 程序 。 子 程序 允许 租 套 , 即 程 序 A 调用 程序 B, 程 序 B 又 调用 程序 C, 程 序 C 再 调用 
程序 D…… 这 个 过 程 又 称 为 多 重 转子 。 其 中 ,程序 B 对 于 程序 A 来 说 是 子 程 序 , 而 程序 B 
对 于 程序 C 来 说 是 主 程序 。 男 外 , 子 程序 还 允许 日 己 调 用 自己 , 即 子 程序 递归 。 

从 主 程序 转向 子 程序 的 指令 称 为 子 程 序 调用 指令 ,简称 转子 指令 ,其 助 记 符 一 般 为 
CALL。 转 子 指令 安排 在 主 程序 中 需要 调用 子 程序 的 地 方 , 转 子 指令 是 一 地 址 指令 。 

转子 指令 和 转移 指令 都 可 以 改变 程序 的 执行 顺序 ,但 事实 上 两 者 存在 着 很 大 的 差别 : 

JU 转移 指令 使 程序 转移 到 新 的 地 址 后 继续 执行 指令 ,不 存在 返回 的 问题 ,所 以 没有 返 
回 地 址 ;而 转子 指令 要 考虑 返回 问题 ,所 以 必须 以 某 种 方式 保存 返回 地 址 ,以 便 返 回 时 能 找 
到 原来 的 位 置 。 

多 转移 指令 用 于 实现 同一 程序 内 的 转移 ;而 转子 指令 转 去 执行 一 段子 程序 ,实现 的 是 
不 同 程序 之 间 的 转移 。 


返回 地 址 是 转子 指令 的 下 一 条 指令 的 地 址 ,保存 返回 地 址 的 方法 有 多 种 : 

@ 用 子 程序 的 第 一 个 字 单 元 存放 返回 地 址 。 转 子 指令 把 返回 地 址 存放 在 子 程序 的 第 
一 个 字 单 元 中 , 子 程序 从 第 二 个 字 单 元 开始 执行 。 返 回 时 将 第 一 个 字 单 元 地 址 作为 间接 地 
址 ,采用 间 址 方式 返回 主 程序 。 这 种 方法 可 以 实现 多 重 转子 ,但 不 能 实现 递归 循环 ,如 
Cyber70 机 采用 的 就 是 这 种 方法 。 

多 用 寄存 器 存放 返回 地 址 。 转 子 指令 先 把 返回 地 址 放 到 某 一 个 寄存 需 中 ,再 由 子 程序 
将 寄存 器 中 的 内 容 转 移 到 男 一 个 安全 的 地 方 ,如 主 存 的 某 个 区 域 。 这 是 一 种 较为 安全 的 方 
法 ,可 以 实现 子 程序 的 递归 循环 。IBM 370 机 采用 的 就 是 这 种 方法 ,这 种 方法 相对 增加 了 子 
程序 的 复杂 程度 。 

G) 用 堆栈 保存 返回 地 址 。 不 管 是 多 重 转 子 还 是 子 程序 递归 ,最 后 存放 的 返回 地 址 总 是 
最 先 被 使 用 的 ,堆栈 的 后 进 先 出 存 取 原则 正好 支持 实现 多 重 转 子 和 递归 循环 ,而 且 也 不 增加 
子 程序 的 复杂 程度 。 这 是 应 用 最 为 广泛 的 方法 。 例 如 ,PDP-11、VAX-11 Intel 80x86 机 等 
均 采 用 这 种 方法 。 


3. 返回 指令 


从 子 程序 转向 主 程序 的 指令 称 为 返回 指令 ,其 助 记 符 一 般 为 RET, 子 程序 的 最 后 一 条 
指令 一 定 是 返回 指令 。 人 返回 地 址 存放 的 位 置 决定 了 返回 指令 的 格式 ,通常 返回 地 址 保存 在 
堆栈 中 ,所 以 返回 指令 常 是 零 地 址 指令 。 

转子 和 返回 指令 也 可 以 是 带 条 件 的 ,条 件 转 子 和 条 件 返 回 与 前 述 条 件 转 移 的 条 件 是 相 
同 的 。 


3.4.4 输入 输出 类 指令 


输入 输出 (1/O) 类 指令 用 来 实现 主机 与 外 部 设备 之 间 的 信息 交换 ,包括 输入 输出 数据 、 
主机 向 外 设 发 控制 命令 或 外 设 问 主机 报告 工作 状态 等 。 从 广义 的 角度 看 ,1/O 指令 可 以 归 
和 数据 传送 类 。 各 种 不 同 计算 机 的 W/O 指令 差别 很 大 ,通常 有 两 种 编 址 方式 : 独立 编 址 方 
式 和 统一 编 址 方式 。 


1. 独立 编 址 的 I/O 指令 


独立 编 址 方式 使 用 专门 的 输入 输出 指令 (IN/OUT)。 以 主机 为 基准 ,信息 由 外 设 传送 
给 主机 称 为 输入 ,反之 称 为 输出 。 指 令 中 应 给 出 外 部 设备 编号 (端口 地 址 ) 。 这 些 端口 地 址 
与 主 存 地 址 无 关 ,是 另 一 个 独立 的 地 址 空间 。80x86 的 1/O 指令 采用 的 就 是 独立 编 址 方式 。 


2. 统一 编 址 的 1/O 指令 


所 谓 统一 编 址 ,就 是 把 外 设 寄存 带 和 主 存单 元 统一 编 址 。 在 这 种 方式 下 ,不 需要 专门 的 
I/O 指令 ,就 用 一 般 的 数据 传送 类 指令 来 实现 IO 操作 。 一 个 外 部 设备 通常 至 少 有 两 个 寄 
存 胡 : 数据 寄存 天 以 及 从 令 与 状态 寄存 此 。 每 个 外 设 寄 存 需 部 可 以 由 分 配给 它们 的 唯一 的 
主 存 地 址 来 识别 ,主机 可 以 像 访问 主 存 一 样 去 访问 外 部 设备 的 寄存 硕 。PDP-11 机 采用 的 就 
是 统一 编 址 方式 , 它 把 最 高 4KB 主 存 地 址 作为 外 设 寄 存 器 的 地 址 。 

这 两 种 编 址 方式 各 有 优 缺 点 ,它们 的 比较 如 表 3-2 所 示 。 


加 地 加 
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表 3-2 两 种 编 址 方式 比较 


优 缺 点 独立 编 址 方式 统一 编 址 方式 


外 点 | IO 指令 和 访 存 指令 容易 区 分 ,外 设 地 址 | 总 线 结构 简单 ,全部 访 存 类 指令 都 可 用 于 控制 外 
所 | 线 少 , 译 码 简单 , 主 存 空间 不 会 减少 设 ,可 直接 对 外 设 寄存 器 进行 各 种 运算 


缺点 | 控制 线 增加 了 I/O Read 和 I/O Write 信号 | 占用 主 存 一 部 分 地 址 ,缩小 了 可 用 的 主 存 空间 


3.4.5 80x86 指令 系统 举例 


从 80386 开始 的 微 处 理 器 属于 IA-32 结构 ,下 面 以 部 分 常用 指令 为 例 介 绍 80x86 的 指 


1. MOV 指令 


这 是 一 种 形式 最 简单 .使 用 最 频繁 的 指令 , 它 可 以 实现 寄存 器 与 寄存 器 之 间 .寄存 需 与 
主 存单 元 之 间 的 数据 传送 ,也 可 以 将 立即 数 传送 到 寄存 器 。 

MOV 指令 的 传送 通常 以 字 节 、 字 、 双 字 为 单位 ,应 当 保 持 数 据 宽度 一 致 ,否则 需要 使 用 
汇编 语言 的 指示 符 。 

注意 : MOV 指令 的 源 操作 数 和 目的 操作 数 中 ,必须 有 一 个 在 寄存 器 中 ,不 允许 用 于 两 
个 主 存单 元 之 间 的 数据 传送 ,并 且 不 能 向 代码 寄存 器 (CS) 和 堆栈 寄存 器 (SS) 传 送 数据 。 


2. PUSH/POP 指令 


进 栈 指 令 (PUSH) 可 以 分 别 将 寄存 器 、 主 存 、 段 寄存 器 、 状 态 标志 寄存 器 和 全 部 寄存 器 
(80386 以 上 ) 的 内 容 或 立即 数 奈 人 到 堆栈 中 。 出 栈 指令 (POP) 则 弹出 保存 的 数据 ,但 不 能 
从 堆栈 中 弹出 数据 至 立即 数 , 也 不 能 将 数据 弹出 至 代码 段 寄 存 器 。 

堆栈 位 置 由 堆栈 寄存 器 (SS) 和 堆栈 指针 (SP) 规 定 。 在 80x86 中 ,堆栈 操作 都 是 字 (16 
位 ) 操 作 , 同 时 还 限定 压 和 人 数据 的 来 源 和 弹出 数据 的 去 向 不 能 是 主 存单 元 。 


3. 加 、 减 和 比较 指令 


加 法 /减法 指令 (ADDVSUB) 所 需 的 操作 数 可 以 在 寄存 融 、 主 存 中 ,也 可 以 是 立即 数 。 
加 1 或 减 1 指令 (INCVDEC) 的 操作 数 在 寄存 器 中 。 

比较 指令 (CMP) 是 减法 指令 的 一 个 特殊 变化 , 仍 是 进行 两 数 相 减 的 运算 ,但 结果 不 回 
送 , 即 不 保留 “ 差 ?。 比 较 指 令 的 功能 在 于 不 破坏 原来 的 两 个 操作 数 ,而 仅 设置 相应 的 标 

为 了 实现 高 精度 的 加 减 运算 ( 双 倍 字 长 或 多 字 长 ) ,除去 普通 的 加 、 减 指令 外 还 设置 了 融 
进位 加 指令 (ADC) 和 人 带 借 位 减 指令 (SBB) 。 


4. 乘法 、 除 法 指令 


乘法 允许 进行 字 节 、 字 或 双 字 运算 ,它们 可 以 是 带 符号 的 (IMUL) 或 无 符号 的 (MUL) 
整数 。 被 乘 数 分 别 存放 在 AL、AX 或 EAX 中 , 乘 数 可 在 其 他 数据 寄存 器 中 ,乘积 是 双 倍 宽 
的 数据 , 字 节 乘法 的 积存 放 在 AX 中 , 字 乘 法 的 积存 放 在 DX( 高 16 位 数据 ) 和 AX( 低 16 位 


数据 ) 中 , 双 字 乘法 的 积存 放 在 EDX( 高 32 位 数据 ) 和 EAX( 低 32 位 数据 ) 中 。 

除法 也 可 以 进行 字 节 、 字 或 双 字 运算 。 它 们 也 可 以 是 带 符号 的 (IDIV) 或 无 符号 的 
(DIV) 整 数 。 被 除数 总 是 双 倍 宽 的 数据 。 对 于 8 位 的 除数 ,被 乘 数 存放 在 AX 中 ;对 于 16 
位 的 除数 ,被 除数 存放 在 DX 和 AX 中 ,对 于 32 位 的 除数 ,被 除数 存放 在 EDX 和 EAX 中 。 


5. BCD 运算 和 ASCII 运算 


十 进 制 运算 调整 指令 (DAA) 置 于 ADD 或 ADC 指令 之 后 ,将 加 法 运算 的 结果 调整 为 
BCD 数 的 结果 。 由 于 DAA 指令 只 作用 于 AL 寄存 器 ,因此 这 种 运算 每 次 只 能 做 8 位 加 法 。 

十 进 制 运算 调整 指令 (DAS) 置 于 SUB 或 SBB 指令 之 后 ,将 减法 运算 的 结果 调整 为 
BCD 数 的 结果 。 

ASCII 算术 运算 指令 作用 于 ASCII 码 数字 。AAA、AAM、AAS 分 别 在 加 法 、 乘 法 、 减 
法 之 后 进行 调整 ,AAD 在 除法 之 前 进行 调整 。 


6. 基本 逻辑 指令 


基本 逻辑 指令 包括 与 (AND) .或 COR)、 异 或 (XOR) . 非 C(NOT) 和 测试 (TEST) 指 令 , 它 
们 允许 进行 字 节 、 字 或 双 字 运算 。 

这 些 指 令 主 要 用 于 清 零 和 屏蔽 寄存 器 某 些 位 的 内 容 , 其 操作 会 影响 到 某 些 标志 位 。 例 
如 ,“XOR AX,AX” 指 令 可 以 对 AX 清 零 ,还 可 以 清除 进位 位 和 影响 到 SF 、ZF、PF 标志 位 。 

TEST 指令 实现 AND 的 操作 ,但 不 改变 目的 操作 数 , 仅 仅 影 响 标志 寄存 器 的 标志 位 。 


7. 位 测试 指令 


80386 以 上 的 微 处 理 器 增加 了 位 测试 指令 BT、.BTC、BTR 和 BTS。 测试 以 后 ,将 测试 
结果 装 入 进位 标志 位 ,后 3 条 指令 还 会 改变 被 测试 位 。 


8. 移 位 与 循环 指令 


移 位 指令 分 为 算术 移 位 指令 SAL ( 左 移 )、\SAR ( 右 移 ) 和 逻辑 移 位 指令 SHL( 左 移 )、 
SHR( 右 移 )。 左 移 将 操作 数 的 最 高 位 移 人 进位 标志 位 ,最 低位 补 0; 右 移 将 操作 数 的 最 低位 
移 人 进位 标志 位 ,对 逻辑 右 移 , 最 高 位 补 0, 对 算术 右 移 ,最 高 位 ( 即 带 符号 数 的 符号 位 ) 保 持 
原 值 。 

对 于 80386 以 上 的 微 处 理 带 ,还 有 双 精 度 移 位 指令 SHLD( 左 移 ) 和 SHRD( 右 移 ) ,这 两 
条 指令 有 3 个 操作 数 ,可 以 作用 于 两 个 16 位 或 32 位 寄存 需 ,或 者 作用 于 一 个 16 位 或 32 位 
主 存 单元 与 一 个 寄存 硕 。 

循环 指令 按 是 否 与 进位 标志 位 一 起 循环 又 可 细 分 为 小 循环 (不 带 进位 循环 ) 和 大 循环 
( 带 进位 循环 ) 两 种 ,同时 具有 左 循 环 和 右 循 环 两 种 情况 。 故 共有 小 循环 左 移 (ROL) 、 小 循 
环 右 移 (ROR) 、 大 循环 左 移 (RCL) 、 大 循环 右 移 (RCR)4 种 指令 。 


9. 转移 控制 指令 


转移 控制 指令 包括 无 条 件 转移 指令 、 条 件 转移 指令 和 程序 循环 指令 。 这 些 转移 指令 允 
许 在 执行 程序 过 程 中 跳 过 一 段 程序 , 转 到 主 存 的 任何 部 分 去 执行 男 一 条 指令 。 


ER 
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无 条 件 转 移 指 令 (JMP) 不 受 任 何 条 件 的 约束 , 跳 转 到 由 该 指令 指定 的 存储 单元 地 址 去 
执行 男 一 条 指令 。 

条 件 转 移 需 要 测试 的 标志 位 有 进位 标志 位 (CF) 、 零 标志 位 (ZF) 、 符 号 标志 位 (SF)、 
溢出 标志 位 (OF) 和 奇偶 标志 位 (PF) 等 。 这 些 标 志 位 的 组 合 , 可 以 产生 十 几 种 条 件 转移 
指令 。 若 条 件 满足 , 则 转 到 指令 指定 的 地 址 处 ; 若 条 件 不 满足 , 则 顺序 执行 程序 的 下 一 条 

程序 循环 指令 有 LOOP 指令 和 LOOPE/LOOPNE 指令 。LOOP 指令 将 CX/ECX 减 1 
并 执行 JNZ 指令 。 如 果 CX/ECX 不 等 于 零 , 则 转移 到 指定 的 地 址 去 执行 另外 的 指令 。 如 
果 CX/ECX 为 零 , 则 顺序 执行 下 一 条 指令 。LOOPE/LOOPNE 是 条 件 程 序 循环 指令 ,以 
LOOPE 指令 (等 于 则 循环 ) 为 例 , 如 果 CX/ECX 不 等 于 零 且 等 于 条 件 成立 , 则 执行 转移 ;如 
果 不 等 于 条 件 成 立 或 CX/ECX 减 1 后 为 零 , 则 跳出 循环 。 


10. 子 程序 调用 和 返回 指令 


子 程序 通过 调用 子 程序 指令 (CALL) 调 用 ,通过 返回 指令 (RET) 返 回 。 
在 执行 CALL 指令 时 ,返回 地 址 (CS 和 IP 寄存 器 的 内 容 ) 被 月 动 地 压 人 堆栈 保存 。 在 
执行 RET 指令 时 ,自动 地 从 堆栈 中 弹出 返回 地 址 送 给 CS 和 IP 寄存 需 。 


11. 输入 输出 指令 
80x86 微 处 理 器 中 的 I/O 指令 必须 使 用 AL(8 位 )、AX(16 位 ) 或 EAX(32 位 ) 进 行 传 
送 , 如 表 3-3 所 示 。 在 IO 指令 中 可 以 直接 给 出 1/O 端口 地 址 (Port) ,也 可 以 由 DX 寄存 需 


间接 给 出 I/O 端口 地 址 。 前 者 称 为 直接 端 口 寻 址 ,下 接 端 口 寻 址 最 多 只 能 寻 址 256 个 端口 ; 
后 者 称 为 间接 端口 寻 址 ,间接 端口 寻 址 最 多 可 以 寻 址 65 536 个 端口 。 


表 3-3 80x86 微 处 理 器 的 1/O 指令 


助 记 符 操作 数 完成 的 操作 

IN Acc, Port 把 指定 端口 中 的 内 容 输 入 到 AL、AX 或 EAX 中 

IN Acc, DX 把 DX 寄存 器 所 指定 的 端口 中 的 内 容 输入 到 AL、AX 或 EAX 中 
OUT Port, Acc 将 AL、AX 或 EAX 的 内 容 输出 到 指定 端口 中 


OUT DX, Acc 将 AL、AX 或 EAX 的 内 容 输出 到 由 DX 寄存 器 所 指定 的 端口 中 


3.5 指令 系统 的 发 展 
不 同类 型 的 计算 机 有 各 具 特 色 的 指令 系统 ,由 于 计算 机 的 性 能 、 机 天 结构 和 使 用 环境 不 
同 ,指令 系统 的 差异 也 是 很 大 的 。 
3.5.1] X86 架构 的 扩展 指令 集 


目前 ,主流 微机 使 用 的 指令 系统 都 基于 x86 染 构 ,为 了 提升 处 理 右 各 方面 的 性 能 ,Intel 
和 AMD 公司 又 各 上 自 开 发 了 一 些 新 的 扩展 指令 集 。 扩 展 指令 集中 包含 了 处 理 硕 对 多 媒体 、 
三 维 处 理 等 方面 的 文 持 ,能 够 提高 处 理 融 对 这 些 方面 处 理 的 能 力 。 


1. MMX 指令 集 


MMX(Multi Media eXtension ,多 媒体 扩展 ) 指 令 集 是 Intel 公司 为 Pentium 系列 处 理 
器 所 开发 的 一 项 多 媒体 指令 增强 技术 。MMX 指令 集中 包括 了 57 条 多 媒体 指令 ,通过 这 些 
指令 可 以 一 次 性 处 理 多 个 数据 ,对 视频 .音频 和 图 形 数据 处 理 特 别 有 效 。 


2. SSE 指令 集 


SSE(Streaming SIMD Extension , 流 式 SIMD 扩展 ) 也 称 为 单 指 令 多 数据 流 (Single 
Instruction Multiple Data,SIMD) 。SSE 指令 集 共 有 70 条 指令 ,其 中 包含 提高 三 维 图 形 运 
算 效率 的 50 条 SIMD 浮 点 运算 指令 .12 条 MMX 整数 运算 增强 指令 、8 条 优化 内 存 中 的 连 
续 数 据 块 传输 指令 。 


3. 3DNow 指令 集 


3DNow 指令 集 最 初 由 AMD 公司 推出 ,拥有 21 条 扩展 指令 。3DNow 在 整体 上 与 SSE 
非常 相似 ,但 它 与 SSE 的 侧重 点 又 有 所 不 同 ,3DNow 指令 集 主 要 针对 三 维 建 模 、 坐 标 变换 
和 效果 泻 染 等 三 维 数据 的 处 理 , 在 相应 的 软件 配合 下 ,可 以 大 幅度 提高 处 理 需 的 三 维 处 理性 
能 。 增 强 型 3DNow 共有 45 条 指令 , 比 3DNow 又 增加 了 24 条 指令 。 


4. SSE2 指令 集 


SSE2 包含 了 144 条 指令 ,分 为 SSE 部 分 和 MMX 部 分 。SSE 部 分 主要 负责 处 理 浮 点 
数 , 而 MMX 部 分 则 专门 计算 整数 。 在 指令 处 理 速度 保持 不 变 的 情况 下 ,通过 SSE2 优化 
后 的 程序 和 软件 运行 速度 也 能 够 提高 两 倍 。 由 于 SSE2 指令 集 与 MMX 指令 集 相 兼容 ， 
因此 被 MMX 优化 过 的 程序 很 容易 被 SSE2 再 进行 更 深层 次 的 优化 ,达到 更 好 的 运行 
效果 。 


5.SSE3 指令 集 


SSE3 是 目前 规模 最 小 的 指令 集 , 它 只 有 13 条 指令 ,被 分 为 数据 传输 、 数 据 处 理 、 特 殊 处 
理 .优化 和 超 线 程 性 能 增强 5 个 部 分 。 其 中 , 超 线 程 性 能 增强 是 一 种 全 新 的 指令 集 , 它 可 以 
提升 处 理 硕 的 超 线 程 的 处 理 能 力 , 大 大 简化 超 线 程 的 数据 处 理 过 程 ,使 处 理 天 能 够 更 加 快速 
地 进行 并 行 数 据 处 理 。 

6. SSSE3 指令 集 


SSSE3 是 Intel 公司 针对 SSE3 指令 集 的 一 次 额外 扩充 ,有 32 条 指令 ,进一步 增 
媒体 .图 形 图 像 和 Internet 等 方面 的 处 理 能 力 。 


谢 


在 多 


7. SSE4 指令 集 


SSE4 包含 47 条 指令 ,主要 针对 向 量 绘 图 运算 .三 维 游 戏 加 速 、 视 频 编 码 加 速 及 协同 处 
理 的 加 速 。 
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8. SSES 指令 集 


SSE5 是 AMD 为 了 打破 Intel 公司 在 处 理 需 指令 集 的 垄断 地 位 而 提出 的 ,SSE5 加 入 了 
100 余 条 新 指令 ,其 中 最 引 人 注 目的 就 是 三 操作 数 指 令 及 熔 合 乘法 累积 。 三 操作 数 指令 增 
加 了 操作 数 的 数量 ,使 一 条 x86 指令 能 处 理 2 或 3 笔 数 据 , 从 而 把 多 个 简单 的 指令 整合 到 更 
高 效 的 一 个 单独 指令 中 ,提高 执行 效率 。 熔 合 乘 法 累积 技术 可 结合 乘法 与 其 他 算法 ,保证 只 
用 一 条 指令 就 能 完成 迭代 运算 ,从 而 简化 代码 ,提高 效率 。 


9. AVX 指令 集 

AVX(Advanced Vector eXtensions) 是 Intel 公司 的 SSE 延伸 ,支持 三 操作 数 指令 。 

10. FMA 指令 集 

FMA(Fused Multiply Accumulate) 是 Intel 公司 的 AVX 扩充 指令 集 ,支持 熔 合 乘法 累积 。 
3.5.2 从 复杂 指令 系统 到 精简 指令 系统 


指令 系统 的 发 展 有 两 种 截然 不 同 的 方向 ,一 种 是 增强 原 有 指令 的 功能 ,设置 更 为 复杂 的 
新 指令 实现 软件 功能 的 硬化 ; 另 一 种 是 减少 指令 种 类 和 简化 指令 功能 ,提高 指令 的 执行 速 
度 。 前 者 称 为 复杂 指令 系统 ,后 者 称 为 精简 指令 系统 。 

长 期 以 来 ,计算 机 性 能 的 提高 往往 是 通过 增加 硬件 的 复杂 性 获得 的 , 随 着 VLSI 技术 的 
迅速 发 展 , 人 硬件 成 本 不 断 下 降 ,软件 成 本 不 断 上 升 ,促使 人 们 在 指令 系统 中 增加 更 多 的 指令 
和 更 复杂 的 指令 ,以 适应 不 同 应 用 领域 的 需要 。 这 种 基于 复杂 指令 系统 设计 的 计算 机 称 为 
复杂 指令 系统 计算 机 (Complex Instruction Set Computer,CISC) 。CISC 的 指令 系统 多 达 
几 百 条 指令 ,例如 ,Intel 80x86(IA-32) 就 是 典型 的 CISC, 其 中 Pentium 4 的 指令 条 数 已 达到 
500 多 条 (包括 扩展 的 指令 集 ) 。 

如 此 庞大 的 指令 系统 使 得 计算 机 的 研制 周期 变 得 很 长 ,同时 也 增加 了 设计 失误 的 可 能 
性 ,而 且 由 于 复杂 指令 需 进 行 复杂 的 操作 ,有 时 还 可 能 降低 系统 的 执行 速度 。 通 过 对 传统 的 
CISC 指令 系统 进行 测试 表明 ,各 种 指令 的 使 用 频 度 相差 很 悬殊 。 最 篆 使 用 的 是 一 些 比较 秒 
单 的 指令 ,这 类 指令 仅 占 指令 总 数 的 20% ,但 在 各 种 程序 中 出 现 的 频 度 却 占 80% ,其 余 大 多 
数 指令 是 功能 复杂 的 指令 ,这 类 指令 占 指令 总 数 的 80% ,但 其 使 用 频 度 仅 占 20%。 因 此 ,人 
们 把 这 种 情况 称 为 “20%% 一 80%% 律 >。 从 这 一 事实 出 发 ,人 们 开始 了 对 指令 系统 合理 性 的 研 
究 , 于 是 基于 精 侧 指 令 系统 的 精简 指令 系统 计算 机 (Reduced Instruction Set Computer， 
RISC) 随 之 诞生 。 

RISC 的 中 心思 想 是 要 求 指令 系统 简化 ,尽量 使 用 寄存 器 -寄存 需 操 作 指 令 ,除去 访 存 指 
令 (LOAD 和 STORE) 外 其 他 指令 的 操作 均 在 单 周 期 内 完成 ,指令 格式 力求 一 致 , 寻 址 方式 
尽 可 能 减少 ,并 提高 编译 的 效率 ,最 终 达 到 加 快 机 器 处 理 速度 的 目的 。 


3.5.3 VLIW 和 EPIC 
1. VLIW 和 EPIC 概念 


VLIW 是 英文 “Very Long Instruction Word” 的 缩写 ,中 文 含义 是 “ 超 长 指令 字 ”, 即 一 


种 非常 长 的 指令 组 合 , 它 把 许多 条 指令 连 在 一 起 ,增加 了 运算 的 速度 。 在 这 种 指令 系统 中 ， 
编译 大 把 许多 简单 .独立 的 指令 组 合 到 一 条 指令 字 中 。 当 这 些 指 令 字 从 主 存 中 取出 放 到 处 
理 需 中 时 ,它们 被 容易 地 分 解 成 几 条 简单 的 指令 ,这 些 简单 的 指令 被 分 派 到 一 些 独立 的 执行 
单元 去 执行 。 

EPIC 是 英文 “Explicit Parallel Instruction Code” 的 缩写 ,中 文 含义 是 “ 显 式 并 行 指令 代 
码 ”。EPIC 是 从 VLIW 中 衍生 出 来 的 ,通过 将 多 条 指令 放 入 一 个 指令 字 , 有 效 地 提高 了 
CPU 各 个 计算 功能 部 件 的 利用 效率 ,提高 了 程序 的 性 能 。 

VLIW 和 EPIC 处 理 需 的 指令 集 与 传统 处 理 需 的 指令 集 有 极 大 的 区 别 。 


2，Jntel IA-64 结构 


虽然 80x86 指令 集 功 勋章 车, 但 日 显 疲 态 也 是 人 所 共 知 的 事实 。 随 着 时 间 的 推移 ， 
IA-32 结构 的 局 限 性 越 来 越 明 显 了。 作为 一 种 CISC 架构 , 变 长 指令 结构 ` 有 无 数 种 不 同 的 
指令 格式 ,使 它 难 于 在 执行 中 进行 快速 译 码 ;同时 ,为 了 能 够 使 用 RISC 染 构 上 非常 普遍 的 
流水 线 和 分 文 预测 等 技术 ,Intel 公司 被 迫 增加 了 很 多 复杂 的 设计 。 因 此 ,Intel 公司 决定 抛 
弃 IA-32 结构 ,转向 全 新 的 指令 系统 ,20 世纪 末 , 由 Intel 公司 和 HP 公司 联合 推出 了 彻底 
突破 IA-32 结构 的 IA-64 结构 ,最 大 限度 地 开发 了 指令 级 并 行 操作 。 

Intel 公司 反对 将 IA-64 结构 划 归 到 RISC 或 CISC 的 类 别 中 ,因为 他 们 认为 这 是 EPIC 
架构 ,是 一 种 基于 超 长 指令 字 的 设计 , 它 合并 了 RISC 和 VLIW 技术 方面 的 优势 。 最 早 采 用 
这 种 技术 的 处 理 颖 是 Itanium ,后 来 又 有 了 Itanium 2。 

Itanium 有 128 个 64 位 的 整数 寄存 器 、128 个 82 位 的 浮 点 寄存 器 ,64 个 1 位 的 判定 寄 
存 器 和 8 个 64 位 的 分 支 寄存 需 。Itanium 在 硬件 上 与 IA-32 指令 集 兼 容 , 通 过 翻译 软件 与 

P 公司 的 PA-RISC 指令 集 兼 容 。 


3. 128 位 指令 束 


IA-64 结构 将 3 条 指令 拼接 成 128 位 的 “指令 束 ”, 以 加 快 处 理 速 度 。 每 个 指令 束 里 包 
含 了 3 个 41 位 的 指令 和 1 个 5 位 的 模板 ,如 图 3-17 所 示 。 这 个 5 位 的 模板 包含 了 不 同 指令 
间 的 并 行 信 息 ,编译 器 将 使 用 模板 告诉 CPU ,哪些 指令 可 以 并 行 执行 。 模 板 也 包含 了 指令 
束 的 结束 位 ,用 以 告诉 CPU 这 个 指令 束 是 否 结 束 ,是 否 需 准备 捆绑 下 两 个 或 更 多 的 指 
令 束 。 

41 位 41 位 41 位 5 位 


3-17 IA-64 结构 的 指令 束 格式 


指令 束 中 的 每 条 指令 的 长 度 是 固定 的 , 均 为 41 位 ,由 指令 操作 码 字 段 .判定 寄存 器 字段 
和 3 个 寄存 器 字段 (其 中 2 个 为 源 寄存 器 ,1 个 为 目的 寄存 器 ) 组 成 ,指令 只 对 寄存 器 操作 。 


ER 
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一 个 指令 束 中 的 3 条 指令 之 间 一 定 是 没有 依赖 关系 的 ,由 编译 程序 将 3 条 指令 拼接 成 指令 
束 。 假 设 编 译 程 序 发 现 了 16 条 没有 相互 依赖 关系 的 指令 , 便 可 以 把 它们 拼接 成 6 个 不 同 的 
指令 束 ,前 5 束 里 每 束 3 条 指令 , 剩 下 的 一 条 指令 放 在 第 6 束 里 ,然后 在 模板 里 做 上 相应 的 
标记 。 

指令 束 的 128 位 被 CPU 一 次 装载 并 检测 , 依 徘 指令 的 模板 ,3 条 指令 能 被 不 同 的 执行 
单元 同时 执行 。 任 意 数目 的 指令 束 能 安排 在 指令 组 里 ,一 个 指令 组 是 一 个 彼此 可 以 并 行 
行 并 且 不 发 生 冲 突 的 指令 流 。 


习 题 


3-1 指令 长 度 和 机 器 字 长 有 什么 关系 ? 半 字 长 指令 .单字 长 指令 、 双 字 长 指令 分 别 表 示 什 么 意思 ? 

3-2 ”和 零 地址 指令 的 操作 数 来 自 哪 里 ? 一 地 址 指令 中 , 男 一 个 操作 数 的 地 址 通常 可 采用 什么 寻 址 方式 
获得 ? 各 举 一 例 说 明 。 

3-3” 某 计算 机 为 定 长 指令 字 结 构 ,指令 长 度 为 16 位 ,每 个 操作 数 的 地 址 码 长 为 6 位 ,指令 分 为 无 操作 
数 . 单 操作 数 和 双 操 作 数 3 类 。 若 双 操 作 数 指令 已 有 天 种 ,无 操作 数 指令 已 有 工种 , 问 单 操作 数 指令 最 多 
可 能 有 多 少 种 ? 上 述 3 类 指令 各 自 允 许 的 最 大 指令 条 数 是 多 少 ? 

3-4” 设 某 计 算 机 为 定 长 指令 字 结 构 , 指 令 长 度 为 12 位 ,每 个 地 址 码 占 3 位 , 试 提出 一 种 分 配方 案 , 使 
该 指令 系统 包含 : 4 条 三 地 址 指令 ,8 条 二 地 址 指令 ,180 条 单 地 址 指令 。 

3-5 ”指令 格式 同上 题 , 能 否 构 成 : 三 地 址 指令 4 条, 单 地 址 指令 255 条 , 零 地 址 指令 64 条 ? 为 什么 ? 

3-6 ”指令 中 地 址 码 的 位 数 与 直接 访问 的 主 存 容量 和 最 小 寻 址 单位 有 什么 关系 ? 

3-7 试 比 较 间 接 寻 址 和 寄存 器 间 址 。 

3-8 试 比 较 基 址 寻 址 和 变 址 寻 址 。 

3-9 某 计 算 机 字 长 为 16 位 , 主 存 容量 为 64K 字 ,采用 单字 长 单 地址 指令 ,共有 50 条 指令 。 假 设 有 直 
接 寻 址 、 间 接 寻 址 、 变 址 寻 址 和 相对 寻 址 4 种 寻 址 方式 , 试 设计 其 指令 格式 。 

3-10” 某 计算 机 字 长 为 16 位 , 主 存 容量 为 64K 字 , 指 令 格式 为 单字 长 单 地 址 ,共有 64 条 指令 。 试 
说 明 : 

(1) 大 只 采用 直接 寻 址 方式 ,那么 指令 能 访问 多 少 主 存单 元 ? 

(2) 为 扩充 指令 的 寻 址 范围 ,可 采用 直接 /间接 寻 址 方式 , 若 只 增加 一 位 直接 /间接 标志 ,那么 指令 可 寻 
址 范围 为 多 少 ? 指令 直接 寻 址 的 范围 为 多 少 ? 

(3) 采用 页 面 寻 址 方式 , 若 只 增加 一 位 Z/C( 零 页 /现行 页 ) 标 志 , 那 么 指令 寻 址 范围 为 多 少 ? 指令 直接 
寻 址 范围 为 多 少 ? 

(4) 将 (2)、(3) 两 种 方式 结合 ,指令 的 寻 址 范围 为 多 少 ? 指令 直接 寻 址 范围 为 多 少 ? 

3-11 设 某 计 算 机 字 长 为 32 位 ,CPU 有 32 个 32 位 的 通用 寄存 器 ,设计 一 个 能 容纳 64 种 操作 的 单字 
长 指令 系统 。 

(1) 如 果 是 存储 器 间接 寻 址 方式 的 寄存 器 -存储 器 型 指令 ,那么 直接 寻 址 的 最 大 主 存 空 间 是 多 少 ? 

(2) 如 果 采 用 通用 寄存 器 作为 基 址 寄存 器 ,那么 直接 寻 址 的 最 大 主 存 空间 又 是 多 少 ? 

3-12 已 知 某 小 型 机 字 长 为 16 位 ,其 双 操 作 数 指令 的 格式 如 下 : 


其 中 ,OP 为 操作 码 ,R 为 通用 寄存 右 地 址 , 试 说 明 下 列 各 种 情况 下 能 访问 的 最 大 主 存 区 域 有 多 少 机 响 字 。 


(1) A 为 立即 数 。 
(2) A 为 直接 主 存单 元 地 址 。 
(3) A 为 间接 地 址 ( 非 多 重 间 址 ) 。 
(4) A 为 变 址 寻 址 的 形式 地 址 ,假定 变 址 寄存 器 为 Ri ( 字 长 为 16 位 ) 。 区 
3-13 ”计算 下 列 4 条 指令 的 有 效 地 址 (指令 长 度 为 16 位 )。 
(1) 000000Q (2) 100000Q (3) 170710Q (4) 012305Q 
假设 : 上 述 4 条 指令 均 用 八进制 书写 ,指令 的 最 左边 是 一 位 间 址 指示 位 @(@ = 二 0, 直 接 寻 址 ;@= 二 1, 间 

接 寻 址 ), 且 具 有 多 重 间 访 功 能 ; 指令 的 最 右边 两 位 为 形式 地 址 ; 主 存 容量 为 25 个 单元 ， 

表 3-4 为 有 关 主 存单 元 的 内 容 ( 八 进 制 ) 。 


表 3-4 习题 3-13 的 主 存单 元 内 容 


00000 100002 100001 
00001 046710 063215 
00002 054304 077710 
00003 100000 100005 
00004 102543 


3-14 假定 某 计 算 机 的 指令 格式 如 下 : 


ll1 10 9 8 7 6 5 0 
 @ ||P | iz| A 
其 中 ， 

bitl1 王 1: 间接 寻 址 。 

bit8 王 1: 变 址 寄存 器 工 寻 址 。 

bit7 王 1: 变 址 寄存 器 工 寻 址 。 

bit6( 零 页 /现行 页 寻 址 ): Z/C=0, 表 示 0 页 面 ;Z/C=1, 表 示 现 行 页 面 , 即 指令 所 在 页 面 。 

若 主 存 容 量 为 2 个 存储 单元 ,分 为 2 个 页 面 , 每 个 页 面 有 2 个 字 。 

设 有 关 寄 存 器 的 内 容 为 : 

(PC)=0340Q (IL)=1111Q (LT ) 一 0256Q 

试 计 算 下 列 指 令 的 有 效 地 址 。 

(1) 1046Q (2) 2433Q (3) 3215Q (4) 1111Q 

3-15 ”假定 指令 格式 如 下 : 


15 12 11 10 9 8 7 0 
oP | | iv) A 
其 中 ,DVI 为 直接 /间接 寻 址 标志 ,D/I=0 表示 直接 寻 址 ,D/I==1 表示 间接 寻 址 。 其 余 标志 位 同 习 题 3-14 
的 说 明 。 
车 主 存 容 量 为 2" 个 存储 单元 ,分 为 2 个 页 面 ,每 个 页 面 有 2 个 字 。 
设 有 关 寄 存 器 的 内 容 为 : 
(1)=002543Q (1,)=063215Q (PC) =004350Q 


试 计算 下 列 指令 的 有 效 地 址 。 
(1) 152301Q (2) 074013Q (3) 161123Q (4) 140011Q 
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3-16 ” 设 某 计算 机 有 变 址 寻 址 、 间 接 寻 址 和 相对 寻 址 等 寻 址 方式 ,当前 指令 的 地 址 码 部 分 为 001AH， 
正在 执行 的 指令 所 在 地 址 为 1F05H , 变 址 寄存 器 中 的 内 容 为 23AOH。 

(1) 当 执 行 取 数 指令 时 ,如 为 变 址 寻 址 方式 , 则 取出 的 数 是 多 少 ? 

(2) 如 为 间接 寻 址 , 则 取出 的 数 是 多 少 ? 

(3) 当 执 行 转移 指令 时 ,转移 地 址 是 多 少 ? 

已 知 主 存 部 分 地 址 及 相应 内 容 见 表 3-5。 


表 3-5 习题 3-16 的 主 存 部 分 地 址 及 相应 内 容 


内 容 
2600H 
1748H 


地 址 
001AH 
1F05H 
1F1FH 


3-17 ”请 举例 说 明 , 哪 几 种 寻 址 方式 除去 取 指 令 以 外 不 访问 存储 器 ? 哪 几 种 寻 址 方式 除去 取 指 令 以 
外 只 需 访问 一 次 存储 器 ?完成 什么 样 的 指令 (包括 取 指 令 在 内 ) 共 需 访问 4 次 存储 器 ? 

3-18 设 相 对 寻 址 的 转移 指令 占 两 个 字 节 ,第 一 个 字 节 是 操作 码 , 第 二 个 字 节 是 相对 位 移 量 , 用 补 码 
表示 。 假 设 当 前 转移 指令 第 一 字 节 所 在 的 地 址 为 2000H, 且 CPU 每 取 一 个 字 节 便 自 动 地 完成 (PC) 十 1 一 
PC 的 操作 。 试 问 : 当 执 行 JMP* 十 8 和 JMP* 一 9 指令 (* 为 相对 寻 址 特征 ) 时 ,转移 指令 第 二 字 节 的 内 
容 各 为 多 少 ? 转移 的 目的 地 址 各 是 什么 ? 

3-19 在 某 堆栈 计算 机 中 ,用 一 地 址 指令 PUSH POP 及 零 地 址 指令 ADD、MPY 写 出 计算 下 式 

Z=(AX(B+C+D) XE+FXF)X (B+C+D) 
的 程序 。 

3-20 如果 在 上 题 中 增加 一 条 DUP 指令 ,该 指令 的 功能 是 将 栈 顶 内 容 复 制 一 次 。 问 : 上 述 程 序 如 何 
简化 ? 

3-21 什么 叫 主 程序 和 子 程序 ?调用 子 程序 时 还 可 采用 哪 几 种 方法 保存 返回 地 址 ? 画图 说 明 调用 子 
程序 的 过 程 。 

3-22 在 某 些 计算 机 中 ,调用 子 程序 的 方法 是 这 样 实现 的 : 转子 指令 将 返回 地 址 存 人 子 程 序 的 第 一 个 
字 单 元 ,然后 从 第 二 个 字 单 元 开始 执行 子 程序 ,回答 下 列 问题 

(1) 为 这 种 方法 设计 一 条 从 子 程序 转 到 主 程序 的 返回 指令 。 

(2) 在 这 种 情况 下 ,如 何在 主子 程序 间 进 行 参数 的 传递 ? 

(3) 上 述 方法 是 否 可 用 于 子 程序 的 峙 套 ? 

(4) 上 述 方法 是 否 可 用 于 子 程序 的 递归 ( 即 某 个 子 程序 自己 调用 自己 )? 

(5) 如 果 改 用 堆栈 方法 ,是否 可 实现 (4) 所 提出 的 问题 ? 


ye 
数值 的 机 器 运算 


运算 天 是 计算 机 进行 算术 运算 和 逻辑 运算 的 主要 部 件 , 运 算 天 的 逻辑 结构 取决 于 机 天 
的 指令 系统 、 数 据 表示 方法 和 运算 方法 等 。 本 草 主 要 讨论 数值 数据 在 计算 机 中 实现 算术 运 
算 和 逻辑 运算 的 方法 ,以 及 运算 部 件 的 基本 结构 和 工作 原理 。 


4.1 基本 算术 运算 的 实现 


计算 机 中 最 基本 的 算术 运算 是 加 法 运算 ,加 、 减 . 乘 、 除 运算 最 终 都 可 以 归结 为 加 法 运 
算 。 所 以 ,在 此 讨论 最 基本 的 运算 部 件 一 一 加 法 器 ,以 及 并 行 加 法 器 的 进位 问题 。 


4.1.1 加 法 器 
加 法 副 是 由 全 加 副 再 配 以 其 他 必要 的 逻辑 电路 组 成 的 。 S 
1. 全 加 器 


全 加 器 (FA) 是 最 基本 的 加 法 单元 , 它 有 3 个 输入 量 ; 操作 | 
数 A; 和 B,, 低 位 传 来 的 进位 C，,。 两 个 输出 量 : 本 位 和 S,, 向 高 
位 的 进位 Ci。 全 加 天 的 逻辑 框图 如 图 4-1 所 示 , 其 真 值 表 如 
表 4-1 所 示 。 图 4-1 全 加 器 


表 4-1 全 加 器 真 值 表 


Ai B; 


~ Oooolypyp 


ee 
| 


i 
一 OO 一 OO 一 OO 一 OO . 
ee 
OO 一 OO OO OO OO 


根据 真 值 表 , 可 得 到 全 加 甫 的 逻辑 表达 式 : 
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Em 


S 一 A 人 ;由 Bi 中 Ci-， 
Ci 一 A;B; 十 (A; 由 Bi)C_， 


2. 捉 行 加 法 器 与 并 行 加 法 器 


加 法 器 有 串 行 和 并 行 之 分 。 在 串 行 加 法 器 中 ,只 有 一 个 全 加 器 ,数据 逐 位 串 行 送 入 加 法 
器 进行 运算 ;并行 加 法 器 则 由 多 个 全 加 器 组 成 ,其 位 数 的 多 少 取决 于 机 器 的 字 长 ,数据 的 各 

串 行 加 法 器 如 图 4-2 所 示 。 图 中 FA 是 全 加 器 ,A、B 是 两 个 具有 右 移 功能 的 寄存 器 ， 
C 为 进位 触发 器 。 由 移 位 寄存 器 从 低位 到 高 位 逐 位 串 行 提 供 操 作 数 相 加 。 如 果 操 作 数 长 
7 位 ,加 法 就 要 分 妹 次 进行 ,每 次 产生 一 位 和 , 且 串 行 地 送 回 A 寄存 器 。 进 位 触发 器 用 来 寄 
存 进位 信号 ,以 便 参 与 下 一 次 的 运算 。 


4-2 串 行 加 法 需 


ea 成 本 低 的 优点 ,但 运算 速度 太 慢 ,所 以 除了 某 些 低速 的 专用 运 
算 硕 外 很 少 采 

be 这 是 
因为 虽然 操作 数 的 各 位 是 同时 提供 的 ,但 低位 运算 所 产生 的 进位 会 影响 高 位 的 运算 结果 。 
例如 ,11…11 和 00…01 相 加 ,最 低位 产生 的 进位 将 逐 位 影响 至 最 高 位 ,因此 ,并行 加 法 器 的 
最 长 运算 时 间 主 要 是 由 进位 信号 的 传递 时 间 决 定 的 ,而 每 个 全 加 器 本 身 的 求 和 延迟 只 是 次 
要 因素 。 很 明显 ,提高 并 行 加 法 器 速度 的 关键 是 尽量 加 快 进位 产生 和 传递 的 速度 。 


4.1.2 进位 的 产生 和 传 遂 


并 行 加 法 需 中 的 每 一 个 全 加 需 都 有 一 个 从 低位 送 来 的 进位 输入 和 一 四 位 的 进 
位 输出 。 通 和 常 将 传递 进位 信号 的 逻辑 线路 连接 起 来 构成 的 进位 网 络 称 为 进位 链 。 每 一 位 的 
进位 表达 式 为 : 

C; 一 A;B; 十 (A; 中 Bi,)Ci_， 

其 中 ”Ai;B,” 取 决 于 本 位 参加 运算 的 两 个 数 ,而 与 低位 进位 无 关 , 因 此 称 A;B; 为 进位 产生 后 
数 ( 本 次 进位 产生 ) ,用 G; 表示 ,其 含义 是 : 奋 本 位 的 两 个 输入 均 为 1, 必然 要 回 高 位 产生 进 

“(A; 由 Bi)Ci-i? 不 但 与 本 位 的 两 个 数 有 关 ,还 依赖 于 低位 送 来 的 进位 ,因此 称 A; 由 了 B， 
为 进位 传递 限 数 (低位 进位 传递 ) ,用 P; 表示 ,其 含义 是 : 当 两 个 输入 中 有 一 个 为 1, 低位 传 
来 的 进位 C;_1 将 问 更 高 位 传送 ,所 以 进位 表达 式 又 可 以 写成 : 

Ci 一 Gi 十 PiCi-; 
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把 个 全 加 器 串 接 起 来 ,就 可 进行 两 个 位 数 的 相 加 。 这 种 加 法 器 称 为 串 行进 位 的 并 
行 加 法 器 ,如 图 4-3 所 示 。 串 行进 位 又 称 行 波 进位 ,每 一 级 进位 直接 依赖 于 前 一 级 的 进位 ， 
即 进 位 信号 是 逐 级 形成 的 。 


Cn 
A,; B,; Al BI 
4-3 串 行 进位 的 并 行 加 法 器 
其 中 : Ci 一 Gi 十 Pi Co 


(» 一 Or? Pt 


C, = GG, P,C,_ i 
串 行进 位 的 并 行 加 法 器 的 总 延迟 时 间 与 字 长 成 正比 , 字 长 越 长 , 则 总 延迟 时 间 越 长 。 假 
设 将 一 级 “与 门 交 或 门 2 的 延迟 时 间 定 为 ty, 从 上 述 公 式 中 可 看 出 ,每 一 级 全 加 需 的 进位 延 
述 时 间 为 2ty。 在 字 长 为 n 位 的 情况 下 , 寿 不 考虑 G;、P; 的 形成 时 间 , 从 Co 一 C, 的 最 长 延迟 
时 间 为 2nty( 设 Co 为 加 法 需 最 低位 的 进位 输入 ,C, 为 加 法 需 最 高 位 的 进位 输出 )。 


4.1.3 并 行 加 法 器 的 快速 进位 


显然 , 串 行 进位 方式 的 进位 延迟 时 间 太 长 了 ,要 提高 加 法 运算 的 速度 ,就 要 尽 可 能 地 减 
少 进位 延迟 时 间 ,也 就 是 要 改进 进位 方式 。 
1. 并 行进 位 方式 
并 行进 位 又 称 先 行进 位 、 同 时 进位 ,其 特点 是 各 级 进位 信号 同时 形成 。 
C4 一 (ri 本 
C, 一 Gy 十 PC 一 (Ory 下 Ps, i 
C;=G; 二 PP;C,=G; 下 | A 
C=G 十 PC 二 Go tr Pn 


上 述 各 式 中 所 有 的 进位 输出 仅 由 G;、P; 及 最 低 进 位 输入 Co 决定 ,而 不 依赖 于 其 低位 的 
进位 输入 C;-1 ,因此 各 级 进位 输出 可 以 同时 产生 。 这 种 进位 方式 是 快速 的 ,大 不 考虑 G;、P， 
的 形成 时 间 ,从 Co 一 C, 的 最 长 延迟 时 间 仅 为 2ty, 而 与 字 长 无 关 。 但 是 , 随 着 加 法 器 位 数 的 
增加 ,C; 的 逻辑 表达 式 会 变 得 越 来 越 长 ,输入 变量 会 越 来 越 多 ,这 会 使 电路 结构 变 得 很 复 
杂 ,所 以 ,完全 采用 并 行进 位 是 不 现实 的 。 


2. 分 组 并 行进 位 方式 


实际 上 ,通常 采用 分 组 并 行进 位 方式 。 这 种 进位 方式 是 把 位 字 长 分 为 右 干 小 组 ,在 组 
内 名 位 之 间 实 行 并行 快 速 进位 ,在 组 间 既 可 以 采用 串 行 进位 方式 ,也 可 以 采用 并 行 快速 进位 


EE 
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方式 ,因此 有 两 种 情况 。 

(1) 单 级 先行 进位 方式 (组 内 并 行 、. 组 间 串 行 ) 

以 16 位 加 法 天 为 例 , 可 分 为 4 组 ,每 组 4 位 。 第 一 小 组 组 内 的 进位 逻辑 困 数 Ci、C;、 
| Cs、C4 的 表达 式 与 前 述 相同 ,C 一 C4 信 号 是 同时 产生 的 ,实现 上 述 进 位 逻辑 图 数 的 电路 称 为 
4 位 先行 进位 电路 (CCarry Look Ahead,CLA) ,其 延迟 时 间 是 2ty。 

利用 这 种 4 位 的 CLA 电路 以 及 进位 产生 /传递 电路 和 求 和 电路 可 以 构成 4 位 的 CLA 
加 法 右 。 用 4 个 这 样 的 CLA 加 法 需 , 很 容易 构成 16 位 的 单 级 先行 进位 加 法 希 , 如 图 4-4 
所 示 。 


S16~S13 S12~S9 Se~Ss S4~SI 


Ce 4 位 CLA 
加 法 顷 


4 位 CLA 
加 法 各 


Al2~Ao% 
Bie~B'13 Bi ~Bo Bs~B;s B4~Bi 


4-4 16 位 单 级 先行 进位 加 法 器 


若 不 考虑 G; 、P; 的 形成 时 间 , 从 Co 一 C, 的 最 长 延迟 时 间 为 2mty, 其 中 mx 为 分 组 的 组 
数 。16 位 单 级 先行 进位 加 法 器 ,从 Ci 一 Ce 的 最 长 延迟 时 间 为 4X2ty=8ty, 图 4-5 是 这 种 
加 法 器 的 进位 时 间 图 。 ty 
(2) 多 级 先行 进位 方式 (组 内 并 行 .组 间 并 行 ) 8 
在 单 级 先行 进位 电路 中 ,进位 的 延迟 时 间 是 和 组 56 
数 成 正比 的 ,组 数 越 多 , 则 进位 延迟 时 间 越 长 ,因此 当 4 
加 法 器 的 字 长 较 长 (nn 三 16) 时 ,为 了 加 快 进位 传递 时 2 
间 ,就 有 必要 采用 多 级 先行 进位 方式 。 
下 面 仍 以 字 长 为 16 位 的 加 法 器 作为 例子 ,分 析 
两 级 先行 进位 加 法 器 的 设计 方法 。 第 一 小 组 的 进位 
输出 Cs 可 以 写 为 : 
C, 一 G, 十 P,G; 十 P, P,G, 十 P,P;P,G, 十 P,P;,P,P, Cu 一 G;* +P? Co 
其 中 ,G; 一 G, 十 P,G;: 十 P,P;,G, 十 P,P,P,G ,P* 王 P,P;,P,P, 。 
G7 称 为 组 进位 产生 清 数 ,P7? 称 为 组 进位 传递 滑 数 ,这 两 个 辅助 函数 只 与 P;、G; 有 关 。 
依 此 类 推 ,可 以 得 到 : 
Cs=G2? 二 +P;? C=G? 二 +P;? G? +P? P? Co 
Ca 一 Gy 十 P; G; 十 P; P? Gr 十 P; P; Pr Co 
Ci 一 Gy 十 P: Gy 十 P* P? G; 十 P* P? P; G* 十 P* P: P: Pr Co 
为 了 要 产生 组 进位 函数 ,需要 对 原来 的 CLA 电路 进行 修改 : 
第 一 小 组 内 产生 GY .Pr .Cs `.Cz Ci, 不 产生 C4; 
第 二 小 组 内 产生 G2 、P; .Cr .Ce .Cs ,不 产生 Ce; 
第 三 小 组 内 产生 G3 、P? 、Cu .Co 、Gs ,不 产生 C1s; 
第 四 小 组 内 产生 Gt 、P? 、Cis .Cl 、Cis ,不 产生 Cie 。 


Ci6 C12 Cs C4 CiCoC 
4-5 16 位 单 级 先行 进位 时 间 图 
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这 种 电路 称 为 成 组 先行 进位 电路 (Block Carry Look Ahead,BCLA) ,其 延迟 时 间 是 
2ty。 利 用 这 种 4 位 的 BCLA 电路 以 及 进位 产生 与 传递 电路 和 求 和 电路 可 以 构成 4 位 的 
BCLA 加 法 器 。16 位 的 两 级 先行 进位 加 法 器 可 由 4 个 BCLA 加 法 需 和 1 个 CLA 电路 组 
成 ,如 图 4-6 所 示 。 


4 位 BCLA 
加 法 大 


图 4-6 16 位 两 级 先行 进位 加 法 器 


由 图 4-6 可 见 , 若 不 考虑 G;、P; 的 形成 时 间 ,Co 经 过 2ty 产生 第 一 小 组 的 C1、Cs、C; 及 所 
有 组 进位 产生 函数 Gi 和 组 进位 传递 函数 Pi ; 青 经 过 1， 
2ty, 由 CLA 电路 产生 C4 Cs .Cl 、Cie ;再 经 过 2ty 后 ， 6Lxxx xxx xxx 
才能 产生 第 二 三、 四 小 组 内 的 Cs 一 Cr 、Ce 一 Ci、 
Ci 一 Cis 。 它 的 进位 时 间 图 如 图 4-7 所 示 , 此 时 加 法 
器 的 最 长 进位 延迟 时 间 是 6ty。 

用 同样 的 方法 可 以 扩展 到 多 于 两 级 的 先行 进位 
加 法 需 , 如 用 三 级 先行 进位 结构 设计 64 位 加 法 需 。 
这 种 加 法 需 的 字 长 对 加 法 时 间 影 响 甚 小 ,但 造价 较 高 。 

注意 : 从 图 4-4 和 图 4-6 中 可 以 看 出 ,4 位 CLA 加 法 器 和 4 位 BCLA 加 法 器 的 区 别 仅 
在 于 其 中 的 进位 带 辑 电路 上 ,前 者 产生 进位 输出 信号 Ci 一 Cl, 后 者 产生 进位 输出 信号 
Cs 一 Ci 及 组 进位 产生 和 传递 信号 GY 、PY 。 


4.2 定点 加 减 运 算 


定点 数 的 加 减 运 算 包 括 原 码 、 补 码 和 反 码 3 种 带 符号 数 的 加 减 运算 ,其 中 补 码 加 减 运算 
实现 起 来 最 方便 。 


4.2.1 原 码 加 减 运 算 


对 两 个 数 进行 加 减 运 算 时 ,计算 机 的 实际 操作 是 加 还 是 减 , 不 仅 取 决 于 指令 的 操作 码 ， 
还 取决 于 两 个 操作 数 的 符号 。 例 如 ,加 法 运算 时 可 能 要 做 减法 操作 (两 数 异 号 ) ;而 减法 运算 
时 又 可 能 做 加 法 操作 (两 数 异 号 )。 当 原 码 加 减 运算 时 ,符号 位 并 不 参加 运算 ,只 有 两 数 的 绝 
对 值 参 加 运算 。 首 先 要 判断 参加 运算 的 两 个 操作 数 的 符号 ,再 根据 要 求 决定 进行 相 加 还 是 
相 减 操作 ,最 后 还 要 根据 两 个 操作 数 绝对 值 的 大 小 决定 结果 的 符号 ,整个 运算 过 程 比较 


复杂 。 


C16 C12 Cs (4 Ct 


4-7 16 位 两 级 先行 进位 时 间 图 
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在 大 多 数 计算 机 中 ,通常 只 设置 加 法 器 而 不 设置 减法 器 ,减法 运算 将 转换 为 加 法 运算 来 
实现 。 原 码 运 算 时 ,用 |XX| 十 LY| jx 来 代替 |X| 一 |Y|。 

原 码 加 减 运算 规则 如 下 : 

J 参加 运算 的 操作 数 取 其 绝对 值 。 

@ 奢 做 加 法 运算 , 则 两 数 直 接 相 加 ; 夺 做 减法 运算 , 则 将 减 数 先 变 一 次 补 , 再 进行 加 法 
操作 。 

(3) 运算 之 后 ,可 能 有 两 种 情况 : 

e 有 进位 ,结果 为 正 , 即 得 到 正确 的 结果 。 

。 无 进位 ,结果 为 负 , 则 应 再 变 一 次 补 , 才 能 得 到 正确 的 结果 。 

网 结果 加 上 符号 位 。 

通常 ,把 运算 之 前 的 变 补 称 为 前 变 补 ,运算 之 后 的 变 补 称 为 后 变 补 。 

注意 : 变 补 是 指 所 有 的 二 进 制 数 各 位 变 反 后 最 低位 加 1。 


4.2.2 补 码 加 减 运 算 
补 码 加 减 运算 要 比 原 码 加 减 运算 简单 得 多 。 
1. 补 码 加 法 


两 个 补 码 表示 的 数 相 加 ,符号 位 参加 运算 , 且 两 数 和 的 补 码 等 于 两 数 补 码 之 和 , 即 : 
LX 十 YY 一 [LX 和 十 LY 和 
根据 补 码 定义 ,分 4 种 情况 可 以 证 明 该 式 的 正确 性 。 
(1) X>0,Y>0 
因为 X 盖 0,Y 盖 0, 则 (X 十 Y) 二 0。 
由 补 码 定义 : [= [Y=Y 
所 以 [X 十 [LY]# 王 和 十 Y 王 [X 十 Y] 和 
(2) X=0,Y=0 
因为 XX 二 0,Y 二 0, 则 (X 十 Y) 二 0。 
由 补 码 定 义 : [Xl#=M+X, [YJ]#=M+iY (mod M) 
所 以 ” [XX]# 十 [YY] 二 M 十 XX 十 M 十 Y=M 十 (M 十 XX 十 Y)= 二 M 十 [站 十 Yj] 六 
=[X+YJ# (mod M) 
(3) X>0,Y=0 
由 补 码 定义 ， [XJ]#=X, [YJ]#=M+Y (mod M) 
[Xj] 十 [Yj 久 = 二 久 十 M 十 Y=M 十 XX 十 Y 
有 以 下 两 种 情况 : 
@ 当 (X 十 Y) 三 0 时 ,M 被 丢掉 ,因此 
[Xj] 义 十 [Yj]#= 二 M 十 关 十 Y=[X 十 Yj]# (mod M) 
@ 当 (X 十 Y) 二 0 时 ,由 补 码 定义 有 : 
[X]# 十 [Y] =M 十 X 二 Y 王 LX 十 Y] (mod M) 
(4) X=0,Y>0 
情况 与 (3) 类 似 , 只 要 将 XX、Y 位 置 对 调 即 可 证 明 。 


禾 价 的 机 器 运算 


2. 补 码 减法 


也 可 以 借用 加 法 需 来 实现 减法 运算 ,根据 补 码 加 法 公式 可 以 推出 : 
[X—Yj# 二 LX 十 (一 Y) 和 一 LXJ 和 十 [一 站 

从 补 码 减法 公式 可 以 看 出 ,只 要 求 得 [一 Yj#, 就 可 以 变 减 法 为 加 法 。 下 面 以 定点 整数 
为 例证 明 巾 LYJj# 求 [一 交 寂 的 方法 ,此 法 很 容易 推广 到 定点 小 数 。 

设 LY 和 二 Y.,YiY:…yYy, ,为 便于 观察 将 符号 位 Y, 与 数值 位 之 间 用 喜 号 分 开 。 现 有 下 列 
两 种 情况 。 

(I) 0 

已 知 : [YJ]# =[YJn=0,YY,*…Y, 

故 [—Y n=1Y1 YY 

Y 为 正 数 , 一 Y 则 为 负数 ,根据 原 码 求 补 码 的 方法 ,可 以 得 到 .: 

[Yj]#=1,Y, Ys…Y. 十 1 

人 放生 

已 得 [LY j# =1,YY,*……Y., 

根据 补 码 求 原 码 的 方法 ， [Yjm 二 1,Y1 Y2*…Y, 十 1 

由 于 立 是 负数 , 则 一 Y 为 正 数 , 有 : 

[一 区 和 一 [一 着 一 0,Y YY 十] 

综合 以 上 两 种 情况 ,不 管 Y 的 真 值 为 正 或 为 负 , 已 知 LY 站 求 L 一 YY 外 的 方法 是 : 将 LY jn 
连同 符号 位 一 起 求 反 ,末尾 加 1( 在 定点 小 数 中 这 个 "17 实际 上 是 2 ”)。 将 [一 Yj# 称 为 
[Yj 的 机 响 希 数 , 由 [Yj]# 求 [一 Yj] 杀 的 过 程 称 为 对 [Yj 变 补 ( 求 补 ) ,表示 为 : 

[一 Yj 补 三 上 LLY jn j 变 补 

注意 : 应 将 “ 某 数 的 补 码 表示 ”与 “ 变 补 ”这 两 个 概念 区 分 开 来 。 一 个 负数 由 原 码 表 示 转 
换 成 补 码 表示 时 ,符号 位 是 不 变 的 , 仅 对 数值 位 各 位 变 反 , 末 位 加 “1”。 而 变 补 则 不 论 这 个 数 
的 真 值 是 正 是 负 , 一 律 连同 符号 位 一 起 变 反 ( 所 有 的 二 进 制 位 一 起 变 反 ), 末 位 加 "12。[LY ja 
表示 的 真 值 如 果 是 正 数 , 则 变 补 后 [一 Y] 和 所 表示 的 真 值 变 为 负数 ,反之 亦 然 。 

例 4-1 设 Y== 一 0.0110。 则 有 : 

[Yj 二 1.0110,， [Yj#=1.1010， [一 Yj 二 0.0110 
例 4-2 设 Y=0.0110。 则 有 : 
[Yj 二 0.0110， [Yj 杀 二 0.0110， [一 Yj] 三 1. 1010 


3. 补 码 加 减 运算 规则 


补 码 加 减 运算 规则 如 下 : 

J 参加 运算 的 两 个 操作 数 均 用 补 码 表示 。 

@ 符号 位 作为 数 的 一 部 分 参加 运算 。 

G) 大 做 加 法 运算 , 则 两 数 直 接 相 加 ; 硅 做 减法 运算 , 则 将 被 减 数 与 减 数 的 机 带 负 数 
相 加 。 

@ 运算 结果 仍 用 补 码 表示 。 

例 4-3 设 A=0.1011,B8= 一 0.1110, 求 A 十 忆 。 


加 EE 
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其 中 : [LA]#4=0.1011, [Bja=1.0010 


0.1011 [LA]h 
1.0010 [Bj]a 
1.1101 [LA 十 B] 和 
故 [A 二 Bj]#=1.1101 
A 十 B= 一 0. 0011 
例 4-4 设 A=0.1011,B== 一 0.0010, 求 A 一 B。 
其 中 : [A]=0.1011， [Bj#=1.1110, [一 B] 王 0. 0010 


0.1011 [Aja 
十 0.0010 [一 Bjx 
0.1101 [A—Bj]x 
故 [LA 一 B] =0.1101 
A—B=0. 1101 


4. 符号 扩展 


在 计算 机 算术 运算 中 ,有 时 必须 将 采用 给 定位 数 表示 的 数 转 换 成 具有 更 多 位 数 的 某 种 
表示 形式 。 例 如 , 某 个 程序 需要 将 一 个 8 位 数 与 另外 一 个 32 位 数 相 加 。 要 想得到 正确 的 结 
果 , 在 将 8 位 数 与 32 位 数 相 加 之 前 ,必须 将 8 位 数 转换 成 32 位 数 形式 ,这 个 过 程 称 为 “符号 
扩展 ”。 

对 于 正 数 的 符号 扩展 非常 简单 , 原 有 形式 的 符号 位 移动 到 新 形式 的 符号 位 上 ,新 表示 形 
式 的 所 有 附加 位 都 用 ”07 进行 填充 。 

对 于 负数 的 符号 扩展 方法 则 根据 机 器 数 的 不 同 而 不 同 。 原 码 表示 负数 的 符号 扩展 方法 
与 正 数 相同 ,只 不 过 此 时 符号 位 为 "1? 而 已 。 补 码 表示 负数 的 扩展 方法 是 : 原 有 形式 的 符号 
位 移动 到 新 形式 的 符号 位 上 ,新 表示 形式 的 所 有 附加 位 都 用 “1” 进 行 填充 。 

综 上 所 述 , 实 际 上 补 码 的 符号 扩展 非常 简单 ,所 有 附加 位 均 用 符号 位 填充 , 即 正 数 用 “0” 
填充 ,负数 用 “1” 填 充 。 


4.2.3 补 码 的 滋 出 判断 与 检测 方法 
1. 溢出 的 产生 


在 补 码 加 减 运算 中 ,有 时 会 遇 到 这 样 的 情况 : 两 个 正 数 相 加 ,而 结果 的 符号 位 却 为 1( 结 
果 为 负 ) ;两 个 负数 相 加 ,而 结果 的 符号 位 却 为 0( 结 果 为 正 ), 现 以 字 长 为 5 位 的 定点 整数 的 
加 法 运算 举例 如 下 。 
例 4-5 设 X=1011B==11D,Y==111B= 二 7D。 则 有 : 
[X 一 0,1011， [Yj 二 0,0111 
0,1011 [LX 
十 0,0111 [LY jj# 
1,0010 [LX 十 Yj] 
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故 [六 十 Yj 二 1,0010 
X 十 Y= 二 一 1110B== 一 14D 
两 正 数 相 加 结果 为 一 14D, 显 然 是 错误 的 。 


例 4-6 设 X= 一 1011B== 一 11D,Y== 一 111B== 一 7D。 则 有 : 
[六 | 二 1,0101， [Yj 二 1,1001 
1,0101 [XX ji 
1 Il001 [LY 
0,1110  [X+Y]# 


故 [XX 十 Yj 二 0,1110 
XY=1110B=14D 
两 负数 相 加 结果 为 14D, 显 然 也 是 错误 的 。 
为 什么 会 发 生 这 种 错误 呢 ? 原因 在 于 两 数 相 加 之 和 的 数值 已 超过 了 机 需 允 许 的 表示 范 
围 。 字 长 为 2 十 1 位 的 定点 整数 (其 中 一 位 为 符号 位 ), 采 用 补 码 表 示 , 当 运算 结果 大 于 2” 一 1 
或 小 于 一 2 时 ,就 产生 溢出 。 
设 参加 运算 的 两 数 为 X 和 Y, 做 加 法 运算 。 
e 硅 X 和 YY 异 号 ,实际 上 是 做 两 数 相 减 ,所 以 不 会 溢出 。 
。 太 和 YY 同 号 ,运算 结果 为 正 且 大 于 所 能 表示 的 最 大 正 数 或 运算 结果 为 负 且 小 于 所 
能 表示 的 最 小 负数 (绝对 值 最 大 的 负数 ) 时 ,产生 溢出 。 将 两 正 数 相 加 产生 的 溢出 称 
为 正 洲 ;反之 ,两 负数 相 加 产生 的 溢出 称 为 希 洲 。 


2. 洲 出 检测 方法 


假设 ,被 操作 数 为 : LX jj 一 久久 1 入 2… 入 。 
操作 数 为 : LY 和 =Y,,Y1Y2°Y., 
其 和 ( 差 ) 为 . [Sl#4=S; A 


(1) 采用 一 个 符号 位 

从 前 述 两 个 例子 还 可 以 看 出 ,采用 一 个 符号 位 检测 溢出 时 , 当 X,.=Y. 王 0,S. 王 1] 时 , 产 
生 正 洲 ; 当 X, 二 Y, 二 1,S, 二 0 时 ,产生 负 溢 。 

溢出 判断 条 件 为 . 

溢出 二 X,Y,S, 十 X,Y,S， 

(2) 采用 进位 位 

两 数 运算 时 ,产生 的 进位 为 : 

其 中 ,C., 为 符号 位 产生 的 进位 ,Ci 为 最 高 数值 位 产生 的 进位 。 

从 前 述 两 个 例子 还 可 以 看 出 ,两 正 数 相 加 , 当 最 高 有 效 位 产生 进位 (Ci = 二 1) 而 符号 位 不 
产生 进位 (C, 二 0) 时 ,发 生 正 溢 ; 两 负数 相 加 , 当 最 高 有 效 位 不 产生 进位 (Ci = 二 0) 而 符号 位 产 
生 进位 (C., 二 1) 时 ,发 生 钠 洲 。 故 洲 出 条 件 为 . 

溢出 =C,Ci 十 C,Ci=C, 外 CG 
(3) 采用 变形 补 码 ( 双 符号 位 补 码 ) 


回 地 = 加 
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一 个 符号 位 只 能 表示 正 、 负 两 种 情况 , 当 产 生 洲 出 时 ,符号 位 的 含义 就 会 发 生 混 乱 。 如 
果 将 符号 位 扩充 为 两 位 (S, 和 Ss ), 其 所 能 表示 的 信息 量 将 随 之 扩大 , 既 能 检测 出 是 否 洲 
出 ,又 能 指出 结果 的 符号 。 在 双 符 号 位 的 情况 下 ,把 左边 的 符号 位 Ss, 称 为 真 符 ,因为 它 代表 
了 该 数 真正 的 符号 ,两 个 符号 位 都 作为 数 的 一 部 分 参加 运算 。 这 种 编码 又 称 为 变形 补 码 。 
双 符 号 位 的 含义 如 下 : 
Ss1Ss% =00 结果 为 正 数 ,无 淤 出 
Ss1S =01 结果 正 洲 
552 一 10 结果 负 海 
Snes 结果 为 负数 ,无 液 出 
当 两 位 符号 位 的 值 不 一 致 时 ,表明 产生 溢出 ,溢出 条 件 为 : 
洲 出 = Sa 岂 Sw 
如 果 前 述 的 例子 采用 了 双 符 号 位 , 则 有 : 
11 十 7 二 18( 结 果 大 于 最 大 正 数 15) 
00,1011 
十 00,0111 
01,0010 正 海 
一 11 十 (一 7) 王 一 18( 结 果 小 于 绝对 值 最 大 的 负数 一 16) 
11,0101 
十 11,1001 
10,1110 人 负 洲 
双 符 号 位 实质 上 是 扩大 了 模 , 对 于 定点 小 数 来 说 , 模 等 于 4; 对 于 字 长 为 n 十 2 位 的 定点 
整数 来 说 , 模 等 于 2 一 。 
定点 小 数 的 变形 补 码 定义 为 : 
天 0 委 X 一 1 


xls = (44x 1<X<0 “YE® 
字 长 为 n 十 2 位 的 定点 整数 的 变形 补 码 定义 为 : 
x 0<X<2 
4 _2r<X<0 mo 1 


为 了 尽 可 能 减少 代价 ,在 采用 双 符 号 位 方案 时 ,操作 数 和 结果 在 寄存 器 和 主 存 中 仍 保持 
单 符 号 位 , 仅 在 运算 时 再 扩充 为 双 符 号 位 。 


4.2.4 补 码 定点 加 减 运 算 的 实现 


实现 补 码 加 减 运算 的 逻辑 电路 如 图 4-8 所 示 。 

图 4-8 中 下 代表 一 个 多 位 的 并 行 加 法 器 ,其 功能 是 : 接收 参加 运算 的 两 个 数 ,进行 加 法 
运算 ,并 在 输出 端 给 出 本 次 运算 结果 。X 和 YY 是 两 个 寄存 器 ,用 来 存放 参加 运算 的 数据 , 寄 
存 器 X 同时 还 用 来 保存 运算 结果 。 门 A、B、C 分 别 是 字 级 的 与 门 和 与 或 门 , 门 A 用 来 控制 
把 寄存 器 X 各 位 的 输出 送 到 加 法 器 下 的 左 输入 端 ,其 控制 信号 为 X 习 F; 门 C 用 来 控制 把 加 
法 器 下 各 位 的 运算 结果 送 回 寄存 器 X, 其 控制 信号 为 FF 一 X; 门 B 则 通过 两 个 不 同 的 控制 信 
号 YF 和 YF, 分别 实 现 把 寄存 器 Y 各 位 的 内 容 ( 即 各 触发 器 的 Q 端 ) 送 加 法 器 下 ,或 实 
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4-8 补 码 加 减 运算 器 


现 把 寄存 硕 Y 各 位 的 内 容 取 反 后 ( 即 各 触发 大 的 Q 端 ) 送 加 法 需 下 。 加 法 大 下 最 低位 还 有 
一 个 进位 控制 信号 1 FF。CPx 是 寄存 顺 X 的 打 入 脉冲 。 

若 要 实现 补 码 加 法 , 则 需 给 出 X->F、Y->F 和 F->X 这 3 个 控制 信号 ,同时 打开 门 A. 门 
B 和 门 C, 把 寄存 器 X 和 寄存 器 Y 的 内 容 送 入 加 法 器 的 两 个 输入 端 进行 加 法 运算 ,并 把 结 
果 送 回 , 最 后 由 打 入 脉冲 CPx 打 入 寄存 器 X。 

减法 与 加 法 的 不 同 之 处 在 于 ,加 法 使 用 Y 一 F 控制 信号 ,减法 使 用 Y 一 F 和 1 一 F 控制 
信号 ,其 余 控 制 信号 相同 。 


4.3 市 符号 数 的 移 位 和 舍 入 操作 


在 计算 机 中 ,实现 乘除 运算 的 方案 通常 有 以 下 3 种 . 
J 软件 实现 。 在 低档 微机 中 无 乘除 运算 指令 ,只 能 用 乘法 和 除法 子 程序 来 实现 乘除 运算 。 
@ 在 原 有 实现 加 减 运算 的 运算 需 基 础 上 增加 一 些 逻 辑 线路 ,使 乘除 运算 变换 成 加 减 和 
移 位 操作 。 在 机 融 中 设 有 乘除 指令 。 
设置 专用 的 乘 \ 除 法 絮 , 机 带 中 设 有 相应 的 乘除 指令 。 
管 采用 什么 方案 实现 乘除 法 ,基本 原理 是 相同 的 。 如 果 采 用 第 乌 种 方案 , 则 必然 会 涉 


4.3.1 带 符号 数 的 移 位 操作 


在 第 3 章 中 讨论 过 ,算术 移 位 时 应 保持 数 的 符号 位 不 变 ,而 数值 的 大 小 则 要 发 生变 化 。 
左 移 一 位 相当 于 该 数 乘 以 2 ,而 右 移 一 位 相当 于 该 数 除 以 2。 


1. 原 码 的 移 位 规则 


论 正 数 还 是 负数 ,在 左 移 或 右 移 时 ,符号 位 均 不 变 , 空 出 位 一 律 以 “0” 补 入 。 
ppp 
左 移 : 移 位 前 有 1 Ai 和 2" 入 一 

移 位 后 有 1 X:，Xas… X， 
右 移 : 移 位 前 有 1 Xi X,…: 


:2 
0 
I 
移 位 后 有 1 0 Xi… X，，X， 


~ 


才 上 汕 
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2. 补 码 的 移 位 规则 


(1) 正 数 
符号 位 不 变 , 不 论 左 移 或 右 移 , 空 出 位 一 律 以 “0” 补 入 。 
(2) 负数 


符号 位 不 变 , 左 移 后 的 空 出 位 补 ”0”, 右 移 后 的 空 出 位 补 *1”。 
左 移 : 移 位 前 有 ] 和 1 和 2 入 ,1 和 
移 位 后 有 1 X; X3*… X, 0 
右 移 : 移 位 前 有 1 XI X,… Xi X， 
移 位 后 有 1 1 Xi… X，，X 


3. 移 位 功能 的 实现 
在 计算 机 中 ,通常 移 位 操作 由 移 位 寄存 胡来 实现 ,但 也 有 一 些 计算 机 不 设置 专门 的 移 位 


寄存 器 ,而 在 加 法 器 的 输出 端 加 一 个 移 位 器 。 移 位 | 
器 是 由 与 门 和 或 门 组 成 的 逻辑 电路 (实际 上 是 一 个 _ 
多 路 选择 器 ) ,可 以 实现 直 传 (不 移 位 ) 左 斜 一 位 送 
( 左 移 一 位 ) 和 右 斜 一 位 送 ( 右 移 一 位 ) 的 功能 。 移 位 
需 逻 辑 电路 如 图 4-9 所 示 ,分 别 用 2F 一 L、 上 一 L 和 Ta | 
F/2>L 这 3 个 不 同 的 控制 信号 选择 左 移 、 直 传 和 右 “了! pi 
移 操 作 。 Fi_1 F;: Er 

假设 F, 为 加 法 器 的 最 高 位 ,F, 为 加 法 器 的 最 低 图 4-9 移 位 器 


位 。 左 移 相 当 于 乘 以 2, 用 2F-L 信号 控制 ,将 Fi+ 
送 到 Li;; 右 移 相 当 于 除 以 2, 用 F/2L 信号 控制 ,将 FE-: 送 到 L;; 直 传 即 不 移 位 ,用 FL 信 
号 控制 ,将 F; 送 到 L;。 

注意 : 移 位 器 与 移 位 寄存 器 不 同 , 它 本 身 只 有 移 位 功能 ,没有 寄存 功能 ,所 以 移 位 之 后 
的 结果 一 定 要 保存 到 有 关 和 寄存 器 中 。 


4.3.2 带 符 号 数 的 会 入 操作 


在 算术 右 移 时 ,由 于 受到 人 硬件 的 限制 ,运算 结果 有 可 能 需要 舍 去 一 定 的 尾数 ,这 会 造成 
一 些 误差 。 为 了 缩小 误差 ,就 要 进行 舍 人 处理。 假定 经 过 运算 后 的 数 共 有 p 十 g 位 , 现 仅 允 
许 保留 前 p 位 。 舍 入 方法 有 许多 种 ,常见 的 舍 入 方法 有 : 

J 恒 舍 (切断 )。 这 是 一 种 最 容易 实现 的 舍 入 方法 ,无 论 多 余部 分 gq 位 为 何 代码 ,一 律 
舍 去 ,保留 部 分 的 p 位 不 作 任 何 改 变 。 

@ 汉 。 诺 依 曼 舍 入 法 。 这 种 舍 入 法 又 称 为 恒 置 1 法 , 即 不 论 多 余部 分 g 位 为 何 代码 ， 
都 把 保留 部 分 p 位 的 最 低位 置 1。 

(3 下 舍 上 入 法 。 下 舍 上 入 就 是 0 舍 1 入 ,相当 于 十 进 制 中 的 四 舍 五 人 。 用 将 要 舍 去 的 
g 位 的 最 高 位 作为 判断 标志 ,以 决定 保留 部 分 是 否 加 1。 如 果 该 位 为 0, 则 舍 去 整个 g 位 ( 相 
当 于 恒 舍 ) ;如果 该 位 为 1, 则 在 保留 的 p 位 的 最 低位 上 加 1。 

由 查 表 舍 人 法 。 查 表 舍 人 法 又 称 ROM 舍 人 法 ,因为 它 用 ROM 来 存放 舍 入 处 理 表 , 每 
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次 经 查 表 来 读 得 相应 的 处 理 结果 。 查 表 法 的 原理 框图 如 图 4-10 所 示 , 图 中 的 ROM 容量 为 4 
256X7 位 。 通 常 ,ROM 表 的 容量 为 2* 个 单元 ,每 个 单元 字 长 为 K 一 1 位 。 舍 人 处 理 表 的 内 总 
容 设置 一 般 采 用 的 方法 是 : 当天 位 数据 的 高 K 一 1 位 为 全 1 时 ,让 那些 单元 按 恒 合 法 填 人 

K 一 1 位 为 全 1, 其余 单元 都 按 下 合 上 入 法 来 填 其 内 容 。 例 如 ,4 位 数 经 ROM 查 表 , 舍 入 成 。 
3 位 结果 ,其 ROM 的 地 址 和 内 容 的 对 应 关系 如 表 4-2 所 示 。 


表 4-2 ROM 地 址 和 内 容 的 对 应 关系 


地 址 内 容 
0000 010 
0001 011 
0010 011 
0011 100 
1000 110 
1001 111 
1010 111 
1011 111 


图 4-10 查 表 舍 人 法 的 原理 


4.4 定点 乘法 运算 


在 计算 机 中 ,乘法 运算 大 多 数 由 累加 与 移 位 来 实现 ,也 有 些 机 帮 中 具有 由 大 规模 集成 电 
路 制造 的 阵列 乘法 模块 。 


4.4.1 原 码 一 位 乘法 
1. 原 码 一 位 乘法 算法 


原 码 一 位 乘法 是 从 手 算 演 变 而 来 的 , 即 用 两 个 操作 数 的 绝对 值 相 乘 ,乘积 的 符号 为 两 操 
作 数 符号 的 异 或 值 ( 同 号 为 正 , 异 号 为 负 ) , 即 : 
乘积 P=|X|X|Y| 
符号 P,= 二 X,Y, 
式 中 ,P, 为 乘积 的 符号 ,X, 和 YY, 为 被 乘 数 和 乘 数 的 符号 。 
例 4-7 设 XX=0.1101,Y== 一 0.1011, 列 出 手 算 乘法 算式 为 : 


0.1101  --- 被 乘 才 

x 0.1011  --- 乘 数 
1101  --- 部 分 积 

1101 --- 部 分 积 
0000 --- ”部 分 积 

+ 1101 --- ”部 分 积 


0.10001111  --- 乘积 
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因为 P.=X.DY,=0D1=1 

所 以 XXY=—0.10001111 

在 手 算 乘法 中 ,对 应 于 每 一 位 乘 数 求 得 一 项 部 分 积 , 然 后 将 所 有 部 分 积 一 起 相 加 求 得 最 
后 乘积 。 然 而 ,在 计算 机 中 实现 原 码 乘法 时 ,不 能 直接 照搬 上 述 方 法 。 这 是 因为 : 

Q 在 加 法 带 内 很 难 实现 多 个 数据 同时 相 加 。 

多 加 法 需 的 位 数 一 般 与 寄存 需 位 数 相同 ,而 不 是 寄存 器 位 数 的 两 倍 。 

所 以 ,在 计算 机 中 ,通常 把 位 乘 转 化 为 n 次 “累加 与 移 位 ”。 每 一 次 只 求 一 位 乘 数 所 对 
应 的 新 部 分 积 ,并 与 原 部 分 积 作 一 次 累加 ;为 了 节省 需 件 ,用 原 部 分 积 的 右 移 来 代 蔡 新 部 分 
积 的 左 移 。 原 码 一 位 乘法 的 规则 为 : 

中 参加 运算 的 操作 数 取 其 绝对 值 。 

@ 令 乘 数 的 最 低位 为 判断 位 ,各 为 1, 加 被 乘 数 ; 若 为 0, 不 加 被 乘 数 ( 加 0) 。 

G) 累加 后 的 部 分 积 以 及 乘 数 右 移 一 位 。 

@ 重复 nn 次 @@ 和 @，。 

@) 符号 位 单独 处 理 , 同 号 为 正 , 异 号 为 负 。 

通常 ,乘法 运算 需要 3 个 寄存 大 。 被 乘 数 存 放 在 B 寄存 器 中 ; 乘 数 存 放 在 C 寄存 器 中 ; 
A 寄存 颖 用 来 存放 部 分 积 与 最 后 乘积 的 高 位 部 分 , 它 的 初 值 为 0。 运 算 结 束 后 寄存 器 C 中 
不 青 保留 乘 数 , 改 为 存放 乘积 的 低位 部 分 。 

例 4-8 已 知 X 王 0.1101,Y 王 一 0.1011 , 求 XXY。 

|[XI=00. 1101-~>B， |Y|=.1011]->C， 0 一 人 


A C 说 明 
00.0000 |1011 


二 下 | 00.1101 C4=1 ,+|X | 
00.1101 
~ 00.0110 部 分 积 右 移 一 位 
+X| 00.1101 Cs=1 ,+|X| 
01.0011 
> 00.1001 部 分 积 右 移 一 位 
+0 00.0000 Cs=0 , +0 
00.1001 
> 00.0100 部 分 积 右 移 一 位 
+X| 00.1101 Cs=1 ,+| 承 | 
01.0001 
— 00.1000 部 分 积 右 移 一 位 
因为 P,=X,.DY,=0D1=1 
所 以 XXY=—0. 10001111 


原 码 一 位 乘法 的 流程 图 如 图 4-11 所 示 , 图 中 CR 表示 计数 磊 , 用 来 控制 累加 与 移 位 的 
次 数 。 
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2. 原 码 一 位 乘法 运算 的 实现 


实现 原 码 一 位 乘法 运算 器 框图 如 图 4-12 所 示 。 图 中 A、B 是 2 十 2 位 的 寄存 器 ,C 是 7 
位 的 寄存 器 ,A 寄存 器 和 C 寄存 器 是 级 联 在 一 起 的 ,它们 都 具有 右 移 一 位 的 功能 ,在 右 移 控 
制 信号 的 作用 下 ,A 寄存 器 最 低 一 位 的 值 将 移入 C 寄存 器 的 最 高 位 。C 寄存 器 的 最 低位 的 
值 作为 字 级 与 门 的 控制 信号 ,以 控制 加 被 乘 数 还 是 不 加 被 乘 数 ( 即 加 0)。C 寄存 器 中 的 乘 
数 在 逐次 右 移 过 程 中 将 逐步 丢失 ,取而代之 的 是 乘积 的 低位 部 分 。 原 码 一 位 乘法 运算 器 电 
路 中 除去 3 个 寄存 器 外 ,还 需要 一 个 n 十 2 位 的 加 法 器 一 个 计数 器 、n 十 2 个 与 门 (控制 是 否 
加 被 乘 数 ) 和 一 个 异 或 门 (处 理 符号 位 )。 


IX|=BlY|—C 
0 一 人 0 一 CR 


3(A+0)— A 
] 一 w 
53C—C 


Ps 
| 
As 于 
图 4-11 原 码 一 位 乘法 流程 图 图 4-12 原 码 一 位 乘法 运算 器 


4.4.2 补 码 一 位 采 法 


虽然 原 码 乘法 比 补 码 乘 法 容易 实现 ,但 因为 补 码 加 减法 简单 ,在 以 加 减 运算 为 主 的 通用 
机 中 操作 数 都 用 补 码 表示 ,所 以 这 类 计算 机 在 做 乘法 时 常 使 用 补 码 乘法 。 


1. 校正 法 


补 码 乘法 不 能 简单 地 套用 原 码 乘法 的 算法 ,这 是 因为 补 码 的 符号 位 是 参加 运算 的 。 所 
谓 校正 法 ,是 将 LX ji 和 和 [LYJj# 按 原 码 规则 运算 ,所 得 结果 根据 情况 再 加 以 校正 ,从 而 得 到 正 
确 的 LXXY |] 补 。 

QD 当 乘 数 Y 二 0 时 ,不 管 被 乘 数 X 的 正 负 都 直接 按 原 码 乘法 运算 ,只 是 移 位 时 按 补 码 
规则 进行 。 

@ 当 乘 数 Y 一 0 时 ,可 以 先 把 LYj] 才 的 符号 位 丢掉 不 管 , 仍 按 原 码 乘法 运算 ,最 后 再 加 上 
[一 Xj 进行 校正 。 


回 地 加 


计算 机 组 成 原理 (第 4 版 ) 


将 上 述 两 种 情况 综合 起 来 ,就 得 到 了 补 码 乘法 的 统一 表达 式 : 
[XXY J] = LX) XX C0. Yi YY,)+[L—X XY, 


2. 比较 法 一 一 Booth 乘法 


校正 法 在 乘 数 为 负数 的 情况 下 ,需要 进行 校正 ,控制 起 来 要 复杂 一 些 , 希 望 有 一 个 对 于 
正 数 和 负数 都 一 致 的 算法 ,这 就 是 比较 法 。 比 较 法 是 英国 的 Booth 夫妇 提出 来 的 ,因此 又 称 
为 Booth 法 。 
假设 被 乘 数 [天 = 三 X.. XXX，, 乘 数 [Y | 宁 二 Ys,. Yi YY，。 
根据 校正 法 的 统一 表达 式 ,有 : 
[XXXY]h 一 [LX]i 和 X (0.Y YY,) 十 [一 Xi XY, 
一 [X] 和 和 X (Yi 2 十 Y 2 十 … 十 Y.2) 十 [一 XXXY， 
一 [X]， X { 一 了 十 (7; 一 切 2) 十 (YY 2 一 7 22) 十 … 
| 
一 [LX] X{(Y 一 Y.) 十 (了 一 Yi)2- 十 … 十 (0 一 了 )2-) 
=[X]# X{(CY: 一 Y.) 十 (Y: 一 Y)2- 十 … 十 (Ya 一 YY )2 一 ) 
式 中 ,Y,. 代 表 符 号 位 ,Y,+ 是 附加 位 , 它 的 初 值 为 0, 增加 附加 位 不 会 影响 运算 结果 。 根 据 上 
式 可 写 出 递 推 公式 : 
[Zo j= 二 0 
[Zi j#=2 (LZoj 久 十 (Yt+i 一 Y,)LXj) 
[ZJj# =2 {LZ jj# 十 CY, 一 Y ,1)LX Jj#} 


[Z,j 匀 二 2 [Zij 匀 十 (Ys 一 Y1)LXj) 

所 以 [XXY J]# =[LZ, 和 补 十 (Yi 一 Y.)LX ja 
式 中 ,LZ 为 初始 部 分 积 ,L2# 一 L2,j# 依 次 为 各 次 求 得 的 累加 并 右 移 之 后 的 部 分 积 。 

由 上 式 可 以 发 现 , 每 次 运算 取决 于 乘 数 相 邻 两 位 Y;、Y;41 的 值 ,把 它们 称 为 乘法 的 判断 
位 。 这 种 运算 是 根据 乘 数 相 邻 两 位 的 比较 结果 (Yi;i1 一 Y;) 来 确定 运算 操作 ,因此 称 为 比 
较 法 。 

Booth 乘法 规则 如 下 : 

J 参加 运算 的 数 用 补 码 表示 。 

G 符号 位 参加 运算 。 

G) 乘 数 最 低位 后 面 增 加 一 位 附加 位 Y,+ ,其 初 值 为 0。 

@ 由 于 每 求 一 次 部 分 积 要 右 移 一 位 ,所 以 乘 数 的 最 低 两 位 YY 的 值 决定 了 每 次 应 
执行 的 操作 ,如 表 4-3 所 示 。 

表 4-3 ”Booth 乘法 运算 操作 


判断 位 了 了， 判断 位 Y, Yi 操作 


0 0 原 部 分 积 十 0, 右 移 一 位 1 0 | 原 部 分 积 十 [一 Xj , 右 移 一 位 
0 1 原 部 分 积 十 LXj# , 右 移 一 位 1 1 | 原 部 分 积 十 0, 右 移 一 位 


3 移 位 按 补 码 右 移 规则 进行 。 
@) 共 需 做 ?十 1 次 累加 ,次 移 位 ,第 ?十 1 次 不 移 位 。 


注意 : 由 于 符号 位 要 参加 运算 ,部 分 积累 加 时 最 高 有 效 位 产生 的 进位 可 能 会 侵占 符号 
位 , 故 被 乘 数 和 部 分 积 应 取 双 符号 位 ,而 乘 数 只 需要 一 位 符号 位 。 运 算 时 仍 需要 有 3 个 寄存 


器 ,各 自 的 作用 与 原 码 时 相同 ,只 不 过 存放 的 内 容 均 为 补 码 而 已 。 
例 4-9 已 知 X= 一 0.1101,Y 二 0.1011, 求 XXY。 
| X | 和 一 -1.0011 一 是 ， [LY jn 一 0.1011 一 L， 0 一 人 
[一 X | 补 = 00. 1101 
A C 附加 位 说 明 


， 
00.0000 0.10110 


+[-X]# 00.1101 C=10 ,4 


00.1101 
~ 00.0110 部 分 积 右 移 一 位 
+0 00.0000 CsCs=11 , +0 
00.0110 
~ 00.0011 部 分 积 右 移 一 位 
+[X]# 11.0011 CsCs=01 ,+[Y]¥ 
110110 | 


— 11.1011 

+[-X] 00.1101 

00.1000 

一 00.0100 

+[X]# 11.0011 
L0111 | 


部 分 积 右 移 一 位 
CaCs=10 ,+[—X ] 补 


部 分 积 右 移 一 位 


CaCs=01 ,+[X ] 补 


所 以 [XXY]#=1.01110001 
XXY=—0.10001111 
Booth 乘法 的 流程 如 图 4-13 所 示 。 


3. Booth 乘法 运算 的 实现 


禾 价 的 机 器 运算 


回 地 = 电 


实现 Booth 乘法 的 运算 器 框图 如 图 4-14 所 示 。 各 器 件 的 作用 与 原 码 一 位 乘法 相同 ， 
A 和 B 寄 存 器 长 nn 十 2 位 ,C 寄存 器 也 有 十 2 位 ,还 需 一 个 nn 十 2 位 的 加 法 器 、n 十 2 个 与 或 门 
和 一 个 计数 需 。 由 CC 寄存 天 的 最 低 两 位 CC+i 来 控制 是 加 / 减 被 乘 数 还 是 加 0， 当 CC+ 
二 01 时 ,加 被 乘 数 , 即 加 B 寄存 右 的 内 容 ;C, C+ 二 10 时 , 减 被 乘 数 , 即 加 上 B 寄存 需 中 内 


容 的 反 ,并 在 加 法 器 的 最 低位 加 1;C,C, 一 00 或 11 时 ,不 加 也 不 减 ( 加 0)。 


与 运算 ,所 以 不 需要 专门 处 理 符 号 位 的 异 或 门 。 


由 于 符号 位 参 


[XX] 补 一 B,[ 芍 补 一 C 
0— A,0— CR,0— 人 Ln+l 


4-14 ”Booth 乘法 运算 器 


4.4.3 补 码 两 位 采 法 
为 了 提高 乘法 的 执行 速度 ,可 以 选用 两 位 乘法 的 方案 。 所 谓 两 位 乘法 ,就 是 每 次 处 
理 乘 数 中 的 两 位 ,从 而 使 乘法 的 速度 提高 了 一 倍 。 为 了 简单 起 见 , 这 里 只 介绍 补 码 两 位 
乘法 。 
可 以 根据 前 面 介 绍 的 Booth 乘法 方便 地 推导 出 补 码 两 位 乘法 , 即 把 补 码 两 位 乘 理解 为 
将 Booth 乘法 的 两 次 合并 为 一 次 来 做 。 
假定 上 次 乘法 的 部 分 积 表示 为 LZ jh ,本 次 的 部 分 积 表示 为 LZ ]#, 则 有 : 
LZ J# =27{[LZ]# 十 (Yin —Y;) LX J]#} 
[2Z” Jj# =271{LZ jj 十 (Yi 一 Yi) LXjJ#} 
一 271{271{[Z]# 十 《Yin 一 Y;) [Xj]#) 十 (Y; 一 Y; 1) [Xj]#) 
二 2 了 2{[Zj] 久 十 (Yin 一 Y;) [Xj 十 2CY; 一 YY;_1)[Xj]#) 
二 2 了 {[Zj] 宁 十 (Yan 十 Y; 一 2Y;_1) [Xj]#) 
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由 上 式 可 见 , 补 码 两 位 乘法 可 以 通过 Y;_1 Y; Yi 3 位 作为 判断 位 来 确定 运算 操作 。 补 
码 两 位 乘法 规则 中 除 由 和 人 外 ,其 余 都 与 Booth 乘法 规则 相同 。 

补 码 两 位 乘法 根据 乘 数 的 最 低 3 位 Y,_1Y,Y,+i 的 值 (做 Yi 十 Y, 一 2Y,-1) 决 定 每 次 应 
执行 的 操作 ,如 表 4-4 所 示 。 

表 4-4 补 码 两 位 乘法 操作 
判断 位 YY。Y,+1 操 作 

原 部 分 积 十 0, 右 移 两 位 
原 部 分 积 十 [Xj , 右 移 两 位 
原 部 分 积 十 LXj , 右 移 两 位 
原 部 分 积 十 2LXj# , 右 移 两 位 
原 部 分 积 十 2[ 一 Xj] , 右 移 两 位 
原 部 分 积 十 [一 Xj] , 右 移 两 位 
原 部 分 积 十 [一 和 Xj , 右 移 两 位 
原 部 分 积 十 0, 右 移 两 位 


0 


OO OO OO CO 
一 OO OO 一 一 OO 
+ OO ”~ OO ”~ OO ~ ODO 


被 乘 数 和 部 分 积 取 3 个 符号 位 , 当 乘 数 的 数值 位 ”为 偶数 时 , 乘 数 取 2 个 符号 位 , 共 需 
作 考 十 1 次 累加 ,地 次 移 位 (最 后 一 次 不 移 位 ); 当 ?为 奇数 时 , 乘 数 只 需 1 个 符号 位 , 共 需 


"次 累加 和 移 位 ,但 最 后 一 次 仅 移 一 位 ， 
例 4-10 已 知 X 王 0.0110011,Y 王 一 0.0110010, 求 XXY。 
[X 直 一 000.0110011 一 B,LY 三 1.1001110 一 C,0 一 A。 
2[X] =000.1100110,[—Xj#=111.1001101,2[—X]#=111.0011010。 


A C ”附加 位 说 明 


000.0000000 站 
+2[-XY]i1110011010 
111.0011010 
111.1100110 
000.0000000 
111.1100110 

2~ 1111111001 1010l11001 部 分 积 右 移 两 位 
+[XY] 0000110011 CeCyCs=001 ,+[X ]a 
000.0101100 
2 一 000.0001011 110 部 分 积 右 移 两 位 


十 [一 ] 补 111.1001101 CiCy Cs=110 ,+[-X]# 
111.1011000 
] 一 111.1101100 0001010I11 最 后 一 次 右 移 一 位 


CeC7Cs=100 , +2[-X ] 补 


101100111 部 分 积 右 移 两 位 
CeC7 Cs=] 11 ， 十 0 


十 
CC 


EE 


计算 机 组 成 原理 (第 4 版 ) 


所 以 [XXY]#=1.11011000001010 
XXY=—0.00100111110110 
至 此 ,介绍 了 原 码 、 补 码 一 位 乘法 和 补 码 两 位 乘法 ,对 于 初学 者 来 说 ,往往 会 在 运算 次 
数 、 符 号 位 取 多 少 位 .符号 位 是 否 参 加 运算 等 问题 上 出 错 , 为 了 帮助 记忆 , 特 将 这 3 种 乘法 运 
算 的 上 述 问题 统一 列 于 表 4-5 中 。 
表 4-5 乘法 运算 总 结 
符 号 位 位 


68 \ 
补 码 两 位 乘法 是 3 

1(n 为 奇数 ) n 十 1 n 十 1] | 2( 最 后 一 次 

2 2 移 一 位 ) 


注 : ”为 乘 数 的 数值 部 分 的 位 数 。 


4.4.4 阵列 乘法 器 


为 了 进一步 提高 乘法 运算 的 速度 ,可 采用 高 速 乘法 模块 组 成 的 阵列 乘法 右 。 设 有 两 个 
无 符号 的 二 进 制 整数 : 


A= 3 B= Tb, xX2i 
j=0 


m—] n—]l m+n—l1 


所 以 P=AXB= > >(aXb)X2cp 一 > PxX2 


i 一 0 j=0 k=0 


例 4-11 在 上 面 公式 中 当 % 二 n= 二 5 时 , 则 有 : 
a4 a3 a a a =4 
xX ba bi  b， bi bo =B 
a4bo asbo azbo albo aobo 
a4bl aa3bl azb! albl aobl 
asb» asb» azb» albz aob; 
aasb3 a3b3 azb3 aib3 aob3 
+ adb4 aasb4 ab4 alb4 aob4 
Po Ps P’ Pse ps Ps Pa PP Pl Po =P 


图 4-15 所 示 为 5X5 位 绝对 值 相 乘 的 阵列 乘法 器 原理 图 。 其 中 ,FA 表示 全 加 器 ,虚线 
框 中 是 具有 并 行进 位 链 的 并 行 加 法 器 。 这 种 结构 可 同时 得 到 各 项 部 分 积 ,并 且 一 次 将 其 相 
加 就 能 得 到 乘积 ,因此 运算 速度 很 快 。 

各 采用 补 码 相 乘 时 ,可 在 上 述 乘 法 阵列 外 再 使 用 3 个 求 补 右 ,其 中 两 个 算 前 求 补 器 将 两 
个 操作 数 在 相 乘 之 前 先 变 成 正 整 数 ,而 一 个 算 后 求 补 需 是 当 绪 果 为 负 ( 即 两 个 操作 数 的 符号 
不 一 致 ) 时 把 运算 结果 变换 成 补 码 。 


a4bo a3bo azbo 


albo 
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aobo 


asbi a2b] oe 3a0bl 
wb (EA) (FA (FA) (EA 


Po Ps Pr Pe Ps Pa P; P» 


4-15 5x5 位 绝对 值 相 乘 的 阵列 乘法 器 原 理 


4.5 定点 除法 运算 


除法 是 乘法 的 逆 运 算 ,与 乘法 运算 的 处 理 思想 相似 ,可 以 将 位 除 转化 成 寿 干 次 “减法 - 


移 位 ”, 也 有 些 计算 机 具有 由 大 规模 集成 电路 制造 的 阵列 除法 模块 。 
4.5.1 原 码 除法 运算 
1. 原 码 比 较 法 和 恢复 余数 法 


(1) 比较 法 

先 看 手工 除法 的 计算 过 程 。 

假设 X==0.1011,Y 二 0.1101, 则 有 : 

0.1101 --- 商 
0.1101 /0.10110 -被 除数 

0.01101 
0.010010 --- 部 分 余数 
0.001101 
0.00010100 --- 部 分 余数 
0.00001101 


0.00000111 -- 余数 


一 入 
所 以 XY=0. A 


Beli0d 


地 上 并 
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手工 计算 的 规则 是 : 首先 判断 被 除数 (或 部 分 余数 ) 和 除数 的 大 小 , 奢 除 数 小 于 或 等 于 
被 除数 (或 部 分 余数 ) 的 最 高 几 位 ,就 将 该 位 商 上 “1”, 并 从 被 除数 (或 部 分 余数 ) 中 减 去 除数 ， 
得 到 新 的 余数 ; 奢 除 数 大 于 被 除数 (或 部 分 余数 ) ,就 将 该 位 商 上 “0”, 被 除数 (或 部 分 余数 ) 不 


| 变 。 然 后 ,将 被 除数 的 下 一 位 挪 下 来 ( 若 存在 ) 或 在 部 分 余数 的 最 低位 补 *0”, 再 与 除数 进行 


比较 ,直至 除 尽 或 得 到 的 商 的 位 数 满足 要 求 为 止 。 

比较 法 类 似 于 手工 运算 ,只 是 为 了 便于 机 如 操作 ,将 除数 右 移 改 为 部 分 余数 左 移 , 每 
一 位 的 上 商 直 接 写 到 寄存 器 的 最 低位 。 设 A 寄存 器 中 存放 被 除数 (或 部 分 余数 ),B 寄存 
全 中 存放 除数 ,C 寄存 天 用 来 存放 商 Q, 夺 A 三 B, 则 上 商 *1”, 并 减 除 数 ; 奢 A 二 B, 则 上 商 
“0”。 比 较 过 程 的 流程 如 图 4-16(a) 所 示 。 比 较 法 需要 设置 比较 线路 ,从 而 增加 了 硬件 的 
代价 。 


图 4-16 ”比较 和 恢复 余数 过 程 流程 图 


(2) 恢复 余数 法 

恢复 余数 法 是 直接 做 减法 试探 方法 ,不管 被 除数 (或 部 分 余数 ) 减 除数 是 否 够 减 , 都 一 律 
先 做 减法 。 若 部 分 余数 为 正 ,表示 人 够 减 , 则 该 位 商 上 “127; 若 部 分 余数 为 负 ,表示 不 够 减 , 则 该 
位 商 上 “0”, 并 要 恢复 余数 。 恢 复 余 数 过 程 的 流程 如 图 4-16(b) 所 示 。 

由 于 部 分 余数 的 正 、 负 是 根据 不 同 的 操作 数组 合 随 机 出 现 的 ,恢复 除数 法 会 使 得 除法 运 
算 的 实际 操作 次 数 不 固定 ,从 而 导致 控制 电路 比较 复杂 。 而 且 在 恢复 余数 时 ,要 多 做 一 次 加 
法 ,从 而 降低 了 除法 的 执行 速度 。 因 此 , 原 码 恢复 余数 法 在 计算 机 中 一 般 很 少 采 用 。 


2. 原 码 不 恢复 余数 法 ( 原 码 加 减 交 替 法 ) 


原 码 不 恢复 余数 法 是 对 恢复 余数 法 的 一 种 改进 , 它 减少 了 浪费 的 加 法 时 间 , 且 运算 的 次 
数 固定 , 故 被 广泛 采用 。 

在 恢复 余数 法 中 ,大 第 i 一 1 次 求 商 的 部 分 余数 为 7;_1, 则 第 i 次 求 商 操作 为 7; 二 
eh 

右 够 减 ,部 分 余数 产 于 2r-: 一 Y>0, 商 1。 

若 不 够 减 , 部 分 余数 x; 二 2r;_1 一 Y 二 0, 商 0, 恢复 余数 后 ,ri 二 ri; 十 Y= 二 2r;_1 ,然后 再 左 移 
一 位 ,进行 第 i 十 1 次 操作 : 

ri 一 他 ;一 YY 一 2(0r: 十 Y) 一 了 一 2r: 十 27 一 > 一 27r; 十 Y 

上 式 表 明 , 当 出 现 不 够 减 的 情况 下 并 不 需要 恢复 余数 ,可 以 直接 做 下 一 次 操作 ,但 操作 

是 2r; 十 Y ,其 结果 与 恢复 余数 后 左 移 一 位 再 减 Y 是 等 效 的 。 因 此 , 原 码 不 恢复 余数 除法 的 
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规则 可 由 下 面 的 通 式 表示 : 
ri+1 三 27; 十 (1 一 2Q;) XY 
式 中 Q; 为 第 i 次 所 得 的 商 , 徊 部 分 余数 为 正 , 则 Qi=1, 部 分 余数 左 移 一 位 ,下 一 次 继续 减 除 
数 ; 耕 部 分 余数 为 负 , 则 Q; 二 0, 部 分 余数 左 移 一 位 ,下 一 次 加 除数 。 由 于 加 减 运算 交替 地 进 
行 , 故 称 为 原 码 加 减 交替 法 。 
除法 运算 需要 3 个 寄存 需 。A 寄存 器 和 B 寄存 器 分 别 用 来 存放 被 除数 和 除数 ,C 寄存 
器 用 来 存放 商 , 它 的 初 值 为 0。 运 算 过 程 中 A 寄存 器 的 内 容 为 部 分 余数 , 它 将 不 断 地 变化 ， 
最 后 剩 下 的 是 扩大 了 知 干 倍 的 余数 ,只 有 将 它 乘 上 2 “" 才 是 真正 的 余数 。 
例 4-12 已 知 X 王 一 0.10101,Y 王 0.11110 , 求 XY。 
IX|=00.10101~A, |Y|=00. 11110 一 B， 0 一 C 
| |Y|j 恋 宁 二 11. 00010 


习 坟 = 加 


A 
00.10101 


+[|Y|] 翅 11.00010 


11.10111 
到 11.01110 


十 了 | 00.11110 


00.01100 
< 一 00.11000 


+[|Y|] 志 #11.00010 


11.11010 
11.10100 


+7| 00.11110 


00.10010 
— 0100100 


+[| 了 |] 恋 补 11.00010 


00.00110 
二 0001100 


二 [| 了 | 上] 六 让 11.00010 


11.01110 


+HY| 0011110 


0001100 


说 明 


-| 
部 分 余数 为 负 ， 商 0 
左 移 一 位 

+ | 

部 分 余数 为 正 ， 商 1 
左 移 一 位 

-| 

部 分 余数 为 负 ， 商 0 
左 移 一 位 

+ 

部 分 余数 为 正 ， 商 1 
左 移 一 位 

-| 

部 分 余数 为 正 ， 商 1 
左 移 一 位 

-| 

部 分 余数 为 负 ， 商 0 


最 后 一 次 恢复 余数 ,+|Y| 


原 码 除法 和 原 码 乘法 一 样 ,符号 位 是 单独 处 理 的 。 所 以 ， 
Q .一 X .dyY =1 中 0=1 


XxX 0. 0 一 


= -(o. ED 


原 码 加 减 交 蔡 除 法 运算 的 算法 流程 图 如 图 4-17 所 示 。 

注意 : 在 定点 小 数 除法 运算 时 ,为 了 防止 溢出 ,要 求 被 除数 的 绝对 值 小 于 除数 的 绝对 
值 ,1X| 二 |YI(|X|I= 二 |Y| 除 外 ), 且 除数 不 能 为 0。 因 此 ,第 一 次 减 除 数 肯 定 是 不 够 减 的 ,如 
果 采 用 先 移 位 后 减 除 数 的 方法 ,得 到 的 结果 也 是 相同 的 。 另 外 ,在 原 码 加 减 交 替 法 中 , 当 最 
终 余 数 为 负数 时 ,必须 恢复 一 次 余数 ,使 之 变 为 正 余数 ,此 时 则 不 需要 再 左 移 了 。 


计算 机 组 成 原理 (第 4 版 ) 


3. 原 码 加 减 交 蔡 除 法 的 实现 


实现 原 码 加 减 交 替 法 的 运算 器 框图 如 图 4-18 所 示 ,A、B 寄存 器 长 2 十 2 位 ,C 寄存 器 长 
n 十 1 位 ,还 需 一 个 n 十 2 位 的 加 法 器 .2 十 2 个 与 或 门 、 一 个 计数 顺和 一 个 异 或 门 。 其 中 ， 
A 寄存 需 和 C 寄存 带 是 级 联 在 一 起 的 ,它们 都 具有 左 移 一 位 的 功能 ,在 左 移 控制 信号 的 作 
用 下 ,C 寄存 需 最 高 位 的 值 将 移入 A 寄存 器 的 最 低位 。A 寄存 需 中 的 初 值 是 被 除数 ,但 在 
运算 过 程 中 将 变 为 部 分 余数 。C 寄存 需 的 最 低位 用 来 保存 每 次 运算 得 到 的 商 值 ,此 商 值 同 
时 也 作为 下 一 次 操作 是 做 加 法 还 是 做 减法 的 控制 信号。 


| 工 | 一 A 人 了 | 一 B 
1 


CR+1 一 


N 


CR 
Y 


0—C, 
[I~ A+B 一 A 加 法 | 


区 2 
IE 
1 1 


图 4-17 原 码 加 减 交 蔡 除 法 流程 图 图 4-18 原 码 加 减 交替 法 运算 器 框图 


4.5.2 补 码 除 法 运算 


被 除数 和 除数 都 用 补 码 表示 ,符号 位 参加 运算 , 商 和 余数 也 用 补 码 表示 ,运算 时 应 考虑 
以 下 问题 。 


1. 够 减 的 判断 


参加 运算 的 两 个 数 符 号 任意 , 当 被 除数 (或 部 分 余数 ) 的 绝对 值 大 于 或 等 于 除数 的 绝对 
值 时 称 为 够 减 ,反之 称 为 不 够 减 。 为 了 判断 是 否 够 减 , 当 两 数 同 号 时 ,实际 应 做 减法 ;两 数 异 
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号 时 ,实际 应 做 加 法 。 

判断 的 方法 和 结果 如 下 : 当 被 除数 (或 部 分 余数 ) 与 除数 同 号 时 ,如 果 得 到 的 新 部 分 余 
数 与 除数 同 号 则 表示 够 减 ,否则 为 不 够 减 ; 当 被 除数 (或 部 分 余数 ) 与 除数 异 号 时 ,如 果 得 到 
的 新 部 分 余数 与 除数 异 号 则 表示 够 减 , 否 则 为 不 够 减 。 


2. 上 商 规 则 


补 码 除法 运算 的 商 也 是 用 补 码 表示 的 ,上 商 的 规则 是 : 如 果 [ Xj 丸和 [Yj 六 同 号 , 则 商 为 
正 数 ,人 够 减 时 上 商 “1”, 不 够 减 时 上 商 “0”; 如 果 LX ji 和 [LYj 让 异 号 , 则 商 为 负数 ,人 够 减 时 上 商 
“0”, 不 够 减 时 上 商 “1”。 

将 上 商 规 则 与 够 减 的 判断 结合 起 来 ,可 得 到 商 的 确定 方法 ,如 表 4-6 所 示 。 


表 4-6 商 的 确定 方法 
[L ] 补 与 LY 上 商 


[X]#* 与 [7]， 
同 号 ,表示 够 减 
同 号 正 一 
异 号 ,表示 不 够 减 


异 号 ,表示 够 减 
异 号 二 
同 号 ,表示 不 够 减 


从 表 4-6 中 可 看 出 , 补 码 的 上 商 规则 可 归结 为 : 各 部 分 余数 [天才 和 除数 LYJj# 同 号 , 则 
商 上 ”12; 反 之 则 商 上 ”0”。 


| OO|IO|—~ 


3. 商 符 的 确定 


商 符 是 在 求 商 的 过 程 中 日 动 形 成 的 , 按 补 码 上 商 规 则 ,第 一 次 得 出 的 商 就 是 实际 应 得 的 
商 符 。 为 了 防止 溢出 ,必须 有 |X| 二 1Y| ,所 以 第 一 次 肯定 不 够 减 。 当 被 除数 与 除数 同 号 时 ， 
部 分 余数 与 除数 必然 异 号 , 商 上 “0”, 愉 好 与 商 符 一 致 ; 当 被 除数 与 除数 异 号 ,部 分 余数 与 除 
数 必 然 同 号 , 商 上 “1”, 也 恰好 就 是 商 的 符号 。 


4. 求 新 部 分 余数 


求 新 部 分 余数 Lriri jh 的 通 式 如 下 : 
Lrs+i 和 三 2Lr 和 和 十 (1 一 2Q) XLY jn 
式 中 ,Q; 表示 第 i 步 的 商 。 奉 商 上 “1”, 则 下 一 步 操作 为 部 分 余数 左 移 一 位 , 减 去 除数 ; 奉 商 
上 “0”, 则 下 一 步 操作 为 部 分 余数 左 移 一 位 ,加 上 除数 。 
补 码 加 减 交 蔡 法 规则 概括 列 于 表 4-7 中 。 


表 4-7 补 码 加 减 交 蔡 法 规则 


[Xj] 与 LY J 第 一 次 操作 Lr; ] 补 与 LY j 补 下 一 次 操作 
QO 同 号 ( 够 减 ) 1 [riri =2[r;] Yj] 
ee jx] yj， 同名 址 | 1 ly =2[r ln — LY] 
@ 异 号 (不 够 减 ) 0 [Lririj 匀 三 2Lri j 匀 十 LY ja 
OD 同 号 (不 够 减 ) [ri J —2Lr; J — [YJ 
异 号 [LXj# 十 [LY jn 
@ 异 号 ( 够 减 ) | 0 | [reqy=2[r]# 十 [Y]# 


才 上 斩 
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s。 末 位 恒 置 1 


假设 商 的 数值 位 为 对 位 ,运算 次 数 为 2 十 1 次 , 商 的 最 末 一 位 恒 置 为 "1”, 运 算 的 最 大 误 
差 为 2“"。 此 法 操作 简单 ,易于 实现 ,在 对 商 的 精度 没有 特殊 要 求 的 情况 下 是 一 种 简单 实用 


的 方法 。 


例 4-13 已 知 X 王 0. 1000,Y== 一 0.1010, 求 XX 二 Y。 


[XX 二 00. 1000 一 A， 
[一 Yj 二 00. 1010 


LY 三 11. 0110 一 B， 0 一 C 


A 说 明 
00.1000 
+ 外 11.0110 [色相 、[ 玉 站 异 号 ，+[ 芭 外 
11.1110 [站 ] 补 、[ 习 同 号 , 商 1 
< 11.1100 左 移 一 位 
+[-Y]# 00.1010 +[—Y ]# 
00.0110 [六 、[ 避 水 异 号 , 商 0 
— 00.1100 左 移 一 位 
+[Y]# 11.0110 十 [六 
00.0010 [i] 补 、[ 习 补 异 号 ,; 商 0 
— 00.0100 左 移 一 位 
+[Y]# 11.0110 二 [了 ] 补 
11.1010 [#4、[ 习 # 同 号 , 商 1 
— 11.0100 左 移 一 位 
+[-Y]i 00.1010 +[ 一 了 ] 站 
11.1110 未 位 恒 置 1 
[他 二 OX 
所 以 补 
他 一 一 0， 1101 十 二 0010 2 一 一 0. 1101 十 二 亲人 0010% 0 


补 码 加 减 交 替 除 法 的 算法 流程 图 如 图 4-19 所 示 。 

实现 补 码 加 减 交 蔡 法 的 运算 器 框图 与 图 4-18 基本 相似 ,只 是 加 减 和 上 商 的 条 件 不 同 ， 
不 需要 异 或 门 来 处 理 符 号 位 而 已 。 

注意 : 无 论 在 原 码 加 减 交替 法 还 是 补 码 加 减 交替 法 的 左 移 过 程 中 ,都 可 能 出 现 左 移 后 
双 符 号 位 不 一 致 的 情况 ,这 是 没有 关系 的 ,不 会 影响 最 后 的 运算 结果 ,因为 此 时 真 符 ( 最 左边 
的 一 位 符号 位 ) 并 没有 发 生变 化 。 

至 此 ,介绍 了 原 码 、 补 码 一 位 除法 ,为 了 帮助 记忆 , 特 将 常用 的 原 码 、 补 码 加 减 交 替 法 的 
运算 次 数 、 符 号 位 等 问题 统一 列 于 表 4-8 中 。 
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[XX] A,LY] 补 一 B 


上 = 


Y A.®B.=0? N 
. A.®B.=0? N 


图 4-19 补 码 加 减 交 替 除 法 的 算法 流程 图 


表 4-8 除法 运算 总 结 


移 位 
除法 类 型 符号 位 参与 运算 加 减 次 数 备 注 


注 : ”为 除数 的 数值 部 分 的 位 数 。 


4.5.3 阵列 除法 器 


和 阵列 乘法 器 相似 ,阵列 除法 右 也 是 一 种 并 行 运算 部 件 ,能 够 实现 高 速 的 除法 运算 。 
图 4-20 是 一 个 实现 加 减 交 蔡 除 法 的 阵列 除法 器 。 设 : 被 除数 义 二 0. Xi1X,X3X4Xs Xe ,除数 
Y= 二 0. 六 YY;, 商 Q= 二 0. QiQ;Q; ,余数 r==0.00rsrirsre。 图 中 的 每 一 个 方 框 为 一 个 可 控 加 法 
和 减法 (CAS) 单 元 , 当 其 输入 控制 端 等 于 0 时 ,CAS 做 加 法 运算 ; 当 输 入 控制 端 等 于 1 时 ， 
CAS 做 减法 运算 。 

在 除法 阵列 中 ,每 一 行 所 执行 的 操作 究竟 是 加 法 还 是 减法 ,取决 于 前 一 行 输出 的 符号 与 
被 除数 的 符号 是 否 一 致 。 当 出 现 不 够 减 时 ,部 分 余数 相对 于 被 除数 来 说 要 改变 符号 ,这 时 应 
该 产生 商 “0”。 除 数 首先 沿 对 角 线 右 移 , 然 后 加 到 下 一 行 的 部 分 余数 上 。 当 部 分 余数 不 改变 


司 地 加 


计算 机 组 成 原理 (第 4 版) 


QO3 


余数 一 户 ra rs 16 


4-20 ”阵列 除法 顺 原 理 


它 的 符号 时 , 即 产生 商 “1”, 下 一 行 操作 应 该 是 减法 。 
4.6 规格 化 浮 点 运算 


第 2 瘟 中 已 经 讨论 了 浮上 点 数 的 表示 方法 ,这 里 将 进一步 讨论 规格 化 浮 点 数 的 四 则 运算 
问题 ,其 中 尾数 的 基数 = 一 2。 


4.6.1 浮 点 加 减 运算 


设 两 个 非 0 的 规格 化 浮上 点数 分 别 为 : 
A 一 MA X2™ 
B= Ms X 2°s 
规格 化 浮 点 数 A、B 加 减 运 算 通 式 为 : 
(Ma 十 Ma X2 ‘5 Ep) ,Ea) Es > E, 
A++B= (Ma,Es)+t (Ms,Es) = 
[a 又 2 Ca 十 Mo,Es) F<E 
式 中 ,2 “a 6 和 2 8 4) 称 为 移 位 因子 。 
1. 浮 点 数 加 减 运算 步骤 


执行 浮 点 数 的 加 减 运算 ,需要 经 过 对 阶 .尾数 加 / 减 、 尾 数 结果 规格 化 、 伟 人 \ 洪 出 判断 等 
步骤 。 

(1) 对 阶 

两 个 浮上 点数 相 加 或 相 减 ,首先 要 把 小 数 点 的 位 置 对 齐 ,而 浮 点 数 的 小 数 点 的 实际 位 置 取 
决 于 阶 码 的 大 小 ,因此 ,对齐 两 数 的 小 数 点 就 是 使 两 数 的 阶 码 相 等 ,这 个 过 程 称 为 对 阶 。 

要 对 阶 , 首 先 应 求 出 两 数 阶 码 Eh 和 gp 之 差 , 即 : 

AE=Es— Es 

若 AE 二 0, 则 表示 两 数 阶 码 相等 , 即 Es 二 Es; 若 AE>0, 则 表示 Es 记 Es ;车 AE 二 0, 则 
表示 Es 二 Es。 

当 A 了 关 Es 时 ,要 通过 尾数 的 移 位 来 改变 EE 或 Es ,使 Es 二 Es 相等 。 对 阶 的 规则 是 : 小 
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阶 回 大 阶 看 齐 。 即 阶 码 小 的 数 的 尾数 右 移 , 每 右 移 一 位 , 阶 码 加 1, 百 到 两 数 的 阶 码 相等 为 
止 。 例 如 

右 Es 二 Es, 则 无 须 对 阶 。 

右 EF4 记 Es, 则 Mas 右 移 。 每 右 移 一 位 ,Es 十 1 一 下 6 ,直至 EF4 一 Es 为 止 。 

右 EF4 二 Es, 则 MA 右 移 。 每 右 移 一 位 ,下 十 1 一 正 4, 直至 EA 一 Es 为 止 。 

尾数 右 移 后 ,应 对 尾数 进行 舍 入 。 

(2) 尾数 加 / 减 

对 阶 之 后 ,就 可 以 进行 尾数 加 / 减 , 即 : 

MstMs—Mc 

其 算法 与 前 面 介 绍 的 定点 加 /减法 相同 。 

(3) 尾数 结果 规格 化 

尾数 加 / 减 运 算 之 后 得 到 的 数 可 能 不 是 规格 化 数 ,为 了 增加 有 效 数 字 的 位 数 ,提高 运算 
精度 ,必须 进行 结果 规格 化 操作 。 规 格 化 的 尾数 M 应 该 满足 下 列 条 件 : 


$<IMI<I 


设 尾数 用 双 符 号 位 补 码 表 示 ,经 过 加 / 减 运 算 之 后 ,可 能 出 现 以 下 6 种 情况 : 
@ 00.1 XX…xX 


© 11.0 X XX 
@ 00.0 X XX 
@ 11.1 X Xx 
© 01. XX XxX.……xX 


© 10. X Xx XX 

第 中 种 和 第 包 种 情况 ,符合 规格 化 数 的 定义 ,已 是 规格 化 数 。 

第 多 种 和 第 由 种 情况 不 是 规格 化 数 ,需要 使 尾数 左 移 以 实现 规格 化 ,这 个 过 程 称 为 左 
规 。 尾 数 每 左 移 一 位 , 阶 码 相应 减 1(Ec 一 1 习 Ec), 直 至 成 为 规格 化 数 为 止 。 只 要 满足 下 列 
条 件 : 

左 规 王 C。 Col Ca Cs (1 
就 进行 左 规 , 左 规 可 以 进行 多 次 。 式 中 ,Cs Cs 表示 尾数 Mc 的 两 个 符号 位 ,Ci 为 Mc 的 最 高 
数值 位 。 

第 书 种 和 第 @ 种 情况 在 定点 加 减 运 算 中 称 为 溢出 ,但 在 浮 点 加 减 运 算 中 只 表明 此 时 尾 
数 的 绝对 值 大 于 1, 而 并 非 真 正 的 溢出 。 这 种 情况 应 将 尾数 右 移 以 实现 规格 化 。 这 个 过 程 
称 为 右 规 。 尾 数 每 右 移 一 位 , 阶 码 相应 加 1(CEc 十 1 一 Ec)。 右 规 的 条 件 如 下 : 

右 规 王 Cs WC 
右 规 最 多 只 有 一 次 。 

(4) 伟人 

由 于 受到 人 硬件 的 限制 ,在 对 阶 和 右 规 处 理 之 后 有 可 能 将 尾数 的 低位 丢失 ,这 会 引起 一 些 
误差 。 舍 人 方法 有 很 多 种 ,最 简单 的 是 恒 舍 法 , 即 无 条 件 的 丢掉 正常 尾数 最 低位 之 后 的 全 部 
数值 。 


EE 
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(5) 溢出 判断 
与 定点 加 减法 一 样 , 浮 点 加 减 运算 最 后 一 步 也 需 进 行 江 出 判断 。 在 前 面 已 经 指出 , 当 尾 
数 之 和 ( 差 ) 出 现 10. X XXX…X 或 01. XXX…X 时 ,并 不 表示 溢出 ,只 有 将 此 数 右 规 后 ,再 


一 = 根据 阶 码 来 判断 浮 点 运算 结果 是 否 溢出 。 


浮 点 数 的 汶 出 情况 由 阶 码 的 符号 决定 , 右 阶 码 也 用 双 符 号 位 补 码 表示 ， 

当 LEc ] 丸 二 01,X XX…X ,表示 上 洲 。 此 时 , 浮 点 数 真 正 溢出 ,机 融 需 停止 运算 ,做 浇 
出 中 断 处 理 。 

当 [LEc jjh 二 10,X XX…X ,表示 下 洲 。 浮 点 数值 趋 于 和 零 ,机 帮 不 做 溢出 处 理 , 而 是 按 机 


2. 浮 点 数 加 减 运 算 举 例 


有 两 浮 点 数 为 
A=0.101110X2™" 
B=—(0.101011) X27 
尾数 和 阶 码 均 为 二 进 制 表示 ,假设 这 两 数 的 格式 为 : 阶 码 4 位 ,用 移 码 ( 偏 置 值 为 2) 表 
示 ; 尾 数 8 位 ,用 补 码 表 示 , 包 含 一 位 符号 位 , 即 : 
阶 码 尾数 
[Al]s=0111;0.1011100 
[Bla=0110;1.0101010 
(1) 对 阶 
求 阶 差 : AFE = Es—Es=—1—(—2)=1 
AEF 王 1, 表 示 巨 As 二 FEs。 按 对 阶 规则 ,将 Ms 右 移 一 位 ,Es 十 1 一 Es ,得 : 
[Be 一 0111;1. 1010101 
(2) 尾数 求 和 
00. 1011100 
十 11. 1010101 
00. 0110001 
(3) 尾数 结果 规格 化 
由 于 结果 的 尾数 是 非 规格 化 的 数 , 故 应 左 规 。 尾 数 左 移 一 位 , 阶 码 减 1。 最 后 结果 是 . 
[LABla=0110;0. 1100010 
即 A 二 +B =(0.110001) X27 ™" 
(4) 伟人 及 洲 出 判断 
运算 结果 不 需要 伟人 处 理 , 且 阶 码 未 发 生 洲 出 。 


4.6.2 浮 点 采 除 运算 


设 两 个 非 0 的 规格 化 浮 点 数 分 别 为 : 
A=Ma X 224 
及 一 Ma X 2°8 


禾 价 的 机 器 运算 


规格 化 浮 点 数 A、B 乘除 运算 通 式 为 : 
(Ma,Ea) X (Ms,Es) = (Ma X Ms,kEa+t Es) 
(Ma ,Ea) | (Ms sb) = (Ma Ms Ea Es) 


1. 乘法 步骤 


两 浮 点 数 相 乘 ,其 乘积 的 阶 码 应 为 相 乘 两 数 的 阶 码 之 和 ,其 乘积 的 尾数 应 为 相 乘 两 数 的 
尾数 之 积 。 即 : 
AXB=M XXX2 5， 
(1) 阶 码 相 加 


如 果 阶 码 用 补 码 表示 , 阶 码 相 加 之 后 无 须 校正 ; 当 阶 码 用 偏 置 值 为 2" 的 移 码 表示 时 , 阶 


码 相 加 后 要 减 去 一 个 俩 置 值 2”。 


因 为 [Es J# =2" 二 En, LEs J# =2” 二 TEs, [EstEs $=2" 二 (En Es) 
而 LE j 移 十 | ls=2 E22+Es=2 T(E TE 
所 以 [EstEs $=LEa $+LEs $C—2" 


显然 ,此 时 阶 码 和 中 多 了 一 个 偏 置 值 2 ,应 将 它 减 去 。 男 外 , 阶 码 相 加 后 有 可 能 产生 洪 
出 ,此 时 应 另 作 处 理 。 

(2) 尾数 相 乘 

若 MA .Ma 都 不 为 0, 则 可 进行 尾数 乘法 。 尾 数 乘法 的 算法 与 前 述 定点 数 乘 法 算法 
相同 。 

(3) 尾数 结果 规格 化 

由 于 A、B 均 是 规格 化 数 ,所 以 尾数 相 乘 后 的 结果 一 定 落 在 下 列 范 围 内 : 


7<IM XMs|<1 
当下 <|IMa XMs1<1 时 ， 乘积 已 是 规格 化 数 , 无 须 再 进行 规格 化 操作 ; 当 一 7<IMX 


Ms | 一 志 时 , 则 需要 左 规 一 次 。 左 规 时 调整 阶 码 后 如 果 发 生 阶 码 下 浇 , 则 作 机 器 零 处 理 。 


2. 除法 步骤 


两 浮 点 数 相 除 , 其 商 的 阶 码 应 为 相 除 两 数 的 阶 码 之 差 ,其 商 的 尾数 应 为 相 除 两 数 的 尾数 

之 商 。 即 : 
A 二 及 一 (MA 二 Map)X244 一 2， 

(1) 尾数 调整 

为 了 保证 商 的 尾数 是 一 个 定点 小 数 ,首先 需要 检测 | MA | 过 | Mas|。 如 果 不 小 于 , 则 Ma 
右 移 一 位 , 尼 十 1 一 下 4 , 称 为 尾数 调整 。 因 为 A、B 都 是 规格 化 数 ,所 以 最 多 调整 一 次 。 

(2) 阶 码 相 减 

如 果 阶 码 用 补 码 表示 , 阶 码 相 减 之 后 无 须 校 正 ; 当 阶 码 用 偶 置 值 为 2 关 的 移 码 表示 时 , 阶 
码 相 减 后 要 加 上 一 个 偏 置 值 2*。 阶 码 相 减 后 ,如 有 洲 出 ,应 男 作 处 理 。 
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(3) 尾数 相 除 
若 Ma 、 Ms 都 不 为 0, 则 可 进行 尾数 除法 。 尾 数 除法 的 算法 与 前 述 定 点 数 除法 算法 相 
同 。 因 为 开始 时 已 进行 了 尾数 调整 ,所 以 运算 结果 一 定 落 在 规格 化 范围 内 , 即 : 


5<IMa + Ms|<1 


4.6.3 浮上 点 运算 器 的 实现 


由 于 浮 点 运算 分 成 阶 码 和 尾数 两 部 分 ,因此 浮 点 运算 如 的 实现 比 定点 运算 带 复 杂 得 多 。 分 
析 上 述 的 浮 点 四 则 运算 可 以 发 现 ,对 于 阶 码 只 有 加 ` 减 运算 ,对 于 尾数 则 有 加 \ 减 ,乘除 4 种 运算 。 
可 见 浮 点 运算 天 主 要 由 两 个 定点 运算 部 件 组 成 ,一 个 是 阶 码 运算 部 件 ,用 来 完成 阶 码 加 、 减 ,以 及 
控制 对 阶 时 小 阶 的 尾数 右 移 次 数 和 规格 化 时 对 阶 码 的 调整 ;为 一 个 是 尾数 运算 部 件 ,用 来 完成 尾 
数 的 四 则 运算 以 及 判断 尾数 是 否 已 规格 化 。 此 外 ,还 宕 要 有 洲 出 判断 电路 等 。 

现代 计算 机 可 把 浮 点 运算 部 件 做 成 任 选 件 , 或 称 为 协 处 理 带 。 所 谓 协 处 理 右 ,是 因为 它 
只 能 协助 主 处 理 器 工作 ,不 能 单独 工作 。 


4.7 ”十进制 整数 的 加 法 运算 


一 些 通用 计算 机 中 设 有 十 进 制 数据 表示 ,可 以 直接 对 十 进 制 整数 进行 算术 和 运算。 下面 
介绍 十 进 制 整数 的 加 法 运算 和 十 进 制 加 法 硕 。 


4.7.1 一 位 十 进 制 加 法 运算 


在 计算 机 中 ,十 进 制 数 是 用 BCD 码 表 示 的 , BCD 码 由 4 位 二 进 制 数 表示 , 按 二 进 制 加 
法 规则 进行 加 法 。 十 进 制 数 的 进位 是 10 ,而 4 位 二 进 制 数 的 进位 是 16 ,为 此 需要 进行 必要 
的 十 进 制 校正 ,才能 使 该 进位 正确 。 因 为 不 同 的 BCD 码 对 应 的 十 进 制 校正 规律 是 不 一 样 
的 ,所 以 硬件 实现 也 是 不 同 的 。 


1. 8421 码 加 法 运算 


8421 码 的 加 法 规则 如 下 : 

Q 两 个 十 进 制 数 的 8421 码 相 加 时 , 按 * 逢 二 进 一 ?” 的 原则 进行 。 
@ 当 和 二 9, 无须 校正 。 

@ 当 和 二 9, 则 十 6 校正 。 

在 做 十 6 校正 的 同时 ,将 产生 向 上 一 位 的 进位 。 

8421 码 的 校正 关系 如 表 4-9 所 示 。 


表 4-9 8421 码 的 校正 关系 


Ca Se Ss Ss I Ce Se 5 9 9 
0 0 0 0 0 0 0 0 0 0 
0 一 9 不 校正 
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续 表 
8421 码 校正 前 的 二 进 制 数 
10 1 0 .000 0 10 10 
11 10001 0 10 11 
12 100 10 0 1 100 
13 100 11 0 1 101 
14 10 100 0 11 10 
15 10 101 01111 EO 
16 10 110 100 00 
17 10 111 10001 
18 1 10 0 0 100 10 
19 1 1001 100 11 


根据 校正 关系 ,很 容易 得 到 : 
校正 函数 二 C4 十 SsSs 十 S45S; 
和 同上 一 位 的 进位 C4 王 校正 函数 。 


2. 余 3 码 加 法 运算 


余 3 码 的 加 法 规则 如 下 : 

Qa 两 个 十 进 制 数 的 余 3 码 相 加 , 按 “ 着 二 进 一 ” 的 原则 进行 。 

多 各 其 和 没有 进位 , 则 减 3( 即 十 1101) 校 正 。 

@) 硅 其 和 有 进位 , 则 加 3( 即 十 0011) 校 正 。 

余 3 码 的 校正 关系 如 表 4-10 所 示 。 

根据 校正 关系 ,很 容易 得 到 校正 函数 : Ci 二 0, 一 3 校正 ;C4 二 1, 十 3 校正 。 向 上 一 位 的 
进位 C4 二 C4 。 


表 4-10 余 3 码 的 校正 关系 


余 3 码 校正 前 的 三 进 制 数 


人 
OO 
OO 
> 


一 3 校正 


1 
1 
0 
0 
0 
0 
1 
1 
1 
1 


‘OO Co ~ 上 品 器 本 ~ OO 
= = 
pO OO OO DO 
一 
OO 一 有 一 ~ OO OO ~ 
OO 一 OO ~ OO ~ OO ~ OO ~ 
= = 
OO 
OO OO 一 一 OO OO 一 ~ 
一 OO 一 OO 一 OO ~ OO ~ 
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续 表 
Cs SS, 9 S$, I [Ca 
10 1]00 1 1 1 0 0 0 
11 1 0 1 0 0 1 0 0 1 
12 1 0 1 0 1 1 0 1 0 
13 1 0 1 1 0 1 0 1 1 
14 | | 1 0 0 0 
19 1 1 0 0 0 1 0 0 1 "Ot 
16 | 1 0 1 0 
if 1 1 0 1 0 1 0 | | 
18 gl | 1 1 0 0 
19 1 1 1 0 0 | i | 0 1 


4.7.2 十 进 制 加 法 器 


1. 一 位 8421 码 加 法 器 


按照 校正 函数 构成 的 8421 码 加 法 器 如 图 4-21 所 示 。 图 中 上 部 4 个 全 加 器 (FA) 实 现 
二 进 制 求 和 运算 ,下 部 一 个 全 加 器 和 两 个 半 加 颖 (HA) 则 用 来 实现 十 6( 十 0110) 的 校正 
操作 。 


A4BI4 A3B; A2B， AIBI 


Co 
Lm 
eit 


94 S3 092 1 
4-21 一 位 8421 码 加 法 器 


2. 一 位 余 3 码 加 法 器 


按照 校正 函数 构成 的 余 3 码 加 法 器 如 图 4-22 所 示 , 图 中 上 部 4 个 全 加 器 实现 二 进 制 
求 和 运算 。 从 表 4-10 可 以 看 出 校正 前 后 最 低位 的 值 永 十 是 相反 的 ,所 以 用 一 个 非 门 使 
Si 求 反 ,这 个 非 门 与 下 部 3 个 全 加 器 一 起 共同 实现 十 3( 十 0011) 或 一 3( 十 1101) 的 校正 
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A4B4 A3Bs3 A2B: AlBI 
0 


才 上 洪 


图 4-22 一 位 余 3 码 加 法 器 


4.7.3 多 位 十 进 制 加 法 


前 面 介绍 了 一 位 十 进 制 加 法 规则 和 加 法 器 ,对 于 多 位 十 进 制 数 来 说 ,完全 遵照 一 位 十 进 
制 数 的 加 法 规则 。 
例 4-14 用 8421 码 求 48 十 36。 
0100 1000 - --- 48 
+ 0011 0110  --- 36 
0111 1110 ”低位 和 大 于 9 
+ 1 一 0110 ”加 6 校正 ， 并 产生 同上 一 位 的 进位 
1000 0100  --- 84 


所 以 48 十 36 一 84。 
例 4-15 用 余 3 码 求 2631 十 1591。 
0101 1001 0110 0100 --- 2631 
+ 0100 1000 1100 0100 --- 1591 
1010 0010 0010 1000 有 进位 +3, 无 进位 -3 
+ 1101 0011 0011 1101 
0111 0101 0101 0101 --- 4222 


所 以 2631 十 1591 一 4222。 

在 例 4-15 中 ,个 位 和 千 位 在 求 和 时 不 产生 进位 ,做 减 3 校正 ;十 位 和 百 位 在 求 和 时 产生 
进位 ,做 加 3 校正 。 

注意 : 校正 前 的 余 3 码 向 高 位 的 进位 均 有 效 , 校 正 后 的 各 余 3 码 向 高 位 的 进位 均 自 动 丢 失 。 

对 于 多 位 十 进 制 数 加 法 可 采用 多 个 BCD 码 加 法 需 , 每 个 BCD 码 加 法 器 就 是 前 述 的 一 
个 一 位 十 进 制 加 法 需 , 可 执行 两 个 一 位 BCD 数 的 加 法 。 大 对 位 BCD 数 相 加 ,由 从 低位 至 高 
位 采用 行 波 式 串 行进 位 的 对 位 十 进 制 加 法 希 完 成 ,如 图 4-23 所 示 。 


图 4-23 寻 位 串 行 十 进 制 加 法 器 
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4.8 ”逻辑 运算 与 实现 


计算 机 在 解 题 过 程 中 ,除了 要 做 大 量 的 算术 运算 外 ,还 需 做 许多 逻辑 操作 ,例如 与 、 或 、 
非 、 异 或 等 。 逻 辑 运 算 比 算术 运算 要 简单 得 多 ,这 是 因为 逻辑 运算 是 按 位 进行 的 ,位 与 位 之 
间 没 有 进位 与 代位 的 关系 。 


1. 逻辑 非 

逻辑 非 又 称 求 反 操 作 , 它 对 某 个 寄存 大 或 主 存 单元 中 各 位 代码 按 位 取 反 。 
假设 : 入 一 和 和 1…AX，， Lp 一 LA0L peL 

则 : Z;=X, (1=0,],*…,n) 

逻辑 非 可 利用 非 门 ( 反 相 兹 ) 实 现 。 

2. 逻辑 乘 

逻辑 乘 就 是 将 两 个 寄存 器 或 主 存单 元 中 的 每 一 相应 位 的 代码 进行 按 位 与 操作 。 
假设 : 入 一 和 人 XIA， Y=YoY.*Y,, L 一 LA0L peL]L 

则 ， Z;=X;AY; (1=0,1,*…,n) 


一 位 二 进 制 数 的 逻辑 乘 规 则 如 表 4-11 所 示 。 
表 4-11 二进制 逻辑 乘 规则 


0 0 | 0 
0 1 | | 1 


逻辑 乘 可 以 用 与 门 来 实现 ,也 可 以 用 或 门 和 非 门 实现 , 即 : 2 一 Xi;AY; 一 XiVYi。 


3. 逻辑 加 

逻辑 加 就 是 将 两 个 寄存 硕 或 主 存单 元 中 的 每 一 相应 位 的 代码 进行 按 位 或 操作 。 
假设 : X=AXoAX1A,, Y=YoY.Y,, 4 一 LoL1…L， 

则 : Z;= XVY, (i=0,],°***,n) 


一 位 二 进 制 数 的 逻辑 加 规则 如 表 4-12 所 示 。 
表 4-12 二进制 逻辑 加 规则 


0 0 0 + 1 
0 1 1 | 1 
逻辑 加 可 以 用 或 门 来 实现 ,也 可 以 用 与 门 和 非 门 实现 , 即 2 = 王 XiVY 王 Xi 人 Y,。 
4. 逻辑 异 或 
逻辑 异 或 又 称 按 位 加 , 它 对 两 个 寄存 需 或 主 存单 元 中 各 位 的 代码 求 模 2 和 。 
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假设 : 和 一 人 AI1 … 入 ,， Y=YoYi oh Z= Zoi “/, 
则 : Z ,一 X, 由 Y， (1=0,],* ,77) 
一 位 二 进 制 数 的 按 位 加 的 运算 规则 如 表 4-13 所 示 。 


表 4-13 ”二进制 按 位 加 规则 
0 0 0 1 0 1 
0 1 1 1 1 
按 位 加 采用 异 或 门 实现 。 


逻辑 运算 操作 既 可 以 由 各 种 专门 设置 的 电路 来 实现 ,也 可 以 利用 算术 人 逻辑 运算 部 件 
(ALU) 来 实现 ,但 在 进行 逻辑 运算 时 要 封锁 进位 链 。 


4.9 运算 融 的 基本 组 成 与 实例 


运算 天 是 在 控制 部 的 控制 下 实现 其 功能 的 。 运 算 需 不 仅 可 以 完成 数据 信息 的 算术 逻辑 
运算 ,还 可 以 作为 数据 信息 的 传送 通路 。 


4.9.1 运算 器 结构 
1. 运算 器 的 基本 组 成 


基本 的 运算 器 包含 以 下 几 个 部 分 : 实现 基本 算术 、 逻 辑 运 算 功 能 的 ALU ,提供 操作 数 
与 暂 存 结果 的 寄存 右 组 ,有 关 的 判别 逻辑 和 控制 电路 等 。 将 这 些 功 能 模块 连接 成 一 个 整体 
时 ,需要 解决 一 个 问题 ,就 是 如 何 向 ALU 提供 操作 数 ? 一 种 方法 是 在 ALU 输入 端 加 多 路 
选择 器 , 男 一 种 方法 是 在 ALU 输入 端 加 一 级 锁 存 器 ( 暂 存 器 ) 。 

运算 器 内 的 各 功能 模块 之 间 的 连接 也 广泛 采用 总 线 结构 ,这 个 总 线 称 为 运算 器 的 内 部 
总 线 ,ALU 和 各 寄存 器 都 挂 在 上 面 。 应当 引 起 大 家 注意 的 是 ,这 里 所 说 的 总 线 与 第 1 章 中 
提 到 的 系统 总 线 的 含义 不 同 , 运 算 需 的 内 部 总 线 是 CPU 的 内 部 数据 通路 ,因此 只 有 数 
据 线 。 

(1) 市 多 路 选择 需 的 运算 需 

图 4-24 为 带 多 路 选择 器 的 运算 器 ,各 寄存 器 可 以 独立 、 多 路 地 将 数据 送 至 ALU 的 多 路 
选择 器 ,使 ALU 有 选择 地 同时 获得 两 路 输入 数据 。 运 算 器 的 内 部 总 线 是 一 组 单 向 传送 的 
数据 线 , 它 将 运算 结果 送 往 各 寄存 器 ,由 寄存 器 的 同步 打 入 脉冲 CP; 将 内 部 总 线 上 的 数据 送 
入 R;。 如 果 同 时 发 出 几 个 打 入 脉冲 , 则 可 将 总 线 上 的 同一 数据 同时 送 入 几 个 相关 的 寄存 
器 中 。 

(2) 带 输 入 锁 存 需 的 运算 需 

图 4-25 为 带 输 入 锁 存 器 的 运算 器 ,运算 器 的 内 部 总 线 是 一 组 双 癌 传送 的 数据 线 。 为 了 
进行 双 操 作 数 之 间 的 运算 操作 ,ALU 输入 端 前 设置 了 一 级 锁 存 器 ,可 暂 存 操作 数 。 例 如 ,要 
实现 (Ro) 十 (Ri1) 习 R, ,可 通过 内 部 总 线 先 将 Ro 中 的 数据 送 入 锁 存 器 1, 再 通过 内 部 总 线 将 
Ri 中 的 数据 送 入 锁 存 器 2, 然 后 相 加 ,并 将 结果 经 总 线 送 入 R,。 


吉 全 怕 
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内 部 总 线 


Ro ~R,，-1 Ro ~R,，-1 
图 4-24 带 多 路 选择 器 的 运算 器 


内 部 总 线 
图 4-25 ” 带 输 入 锁 存 器 的 运算 器 


2. 运算 器 的 内 部 总 线 结构 


运算 絮 的 内 部 总 线 大 体 有 以 下 3 种 结构 形式 。 

(1) 单 总 线 结构 运算 器 

图 4-25 就 是 单 总 线 结构 运算 需 。 这 种 结构 的 运算 需 实 现 一 次 双 操 作 数 的 运算 需要 分 
成 3 步 , 它 的 主要 缺点 是 操作 速度 慢 。 

(2) 双 总 线 结 构 运 算 需 

图 4-26(a) 为 双 总 线 绪 构 运算 需 。 两 个 操作 数 可 以 分 别 通过 总 线 1 和 总 线 2 同时 送 到 
ALU 去 进行 运算 ,并 且 立 即 可 以 得 到 运算 的 结果 。 但 是 ,ALU 的 输出 不 能 直接 送 到 总 线 上 
去 ,这 是 因为 此 时 两 条 总 线 都 被 操作 数 所 占据 着 ,所 以 必须 在 ALU 的 输出 端 设置 一 个 缓冲 
器 , 先 将 运算 结果 送 入 缓冲 器 ,下 一 步 再 把 结果 送 至 目的 寄存 器 。 显 然 , 它 的 执行 速度 比 单 
总 线 要 快 ,每 次 操作 比 单 总 线 少 一 步 。 


图 4-26 多 总 线 结构 运算 器 内 的 数据 通路 
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(3) 三 总 线 结构 运算 天 

三 总 线 结构 运算 需 如 图 4-26(b) 所 示 。ALU 的 两 个 输入 端 分 别 由 两 条 总 线 供 
给 ,输出 与 第 三 条 总 线 相 连 , 这 样 算 本 和 逻辑 运算 操作 就 可 以 在 一 步 控制 之 内 完成 。 
如 果 茶 一 个 数 不 需 要 运算 和 修改 ,而 需要 直接 由 总 线 2 传 到 总 线 3 ,可 通过 总 线 劳 路 
器 把 数据 送出 ,而 不 必 借 助 于 ALU。 三 总 线 结 构 的 特点 是 操作 速度 快 ,但 控制 较 前 
两 种 复 灯 。 


4.9.2 ALU 和 府 例 


本 地 = 加 


1. ALU 电路 


ALU 即 算术 逻辑 单元 , 它 是 既 能 完成 算术 运算 又 能 完成 逻辑 运算 的 部 件 。 巾 于 无 论 是 
加 \ 减 、 乘 、 除 运算 ,最 终 都 能 归结 为 加 法 运算 。 因 此 ,ALU 的 核心 首先 应 当 是 一 个 并 行 加 法 
需 , 同 时 也 能 执行 像 “ 与 交 或 交 非 交 蜡 或 ?这 样 的 逻辑 运算 。 由 于 ALU 能 完成 多 种 功能 ,所 
以 ALU 又 称 多 功能 函数 发 生 费 。 


2. 4 位 ALU 芯片 


过 去 大 多 数 ALU 是 4 位 的 ,目前 随 看 集成 电路 技术 的 发 展 ,多 位 的 ALU 已 相继 问世 。 
为 了 说 明 原 理 , 仍 以 典型 的 4 位 ALU 芯片 (74181) 为 例 介 绍 ALU 的 结构 及 应 用 。 

74181 能 执行 16 种 算术 运算 和 16 种 逻辑 运算 。 工 作 于 正 逻 辑 或 负 逻 辑 的 74181 的 框 
图 分 别 如 图 4-27(a) 、(b) 所 示 。 以 负 逻 辑 为 例 , 其 中 As 一 As 和 了 Bs: 一 Bo 是 两 个 操作 数 ， 
F; 一 Fo 为 输出 结果 ;C, 表 示 最 低位 的 外 来 进位 ,C4 是 向 高 位 的 进位 ;G 为 组 进位 产生 函数 
输出 ,P 为 组 进位 传递 函数 输出 ;M 表示 工作 方式 (M==0 为 算术 操作 ,M=1 为 逻辑 操作 )， 
S; 一 So 为 功能 选择 线 。 


2 1 23 22 21 20 19 18 2 1 23 22 21 20 19 18 

7 JE ho Bo Al B! A, B, As 16 7 
8 8 
0 74181 0 
5 17 5 
4 4 
3 1> 3 

9 10 11 13 

(a) 工作 于 正 逻辑 (b) 工作 于 负 逻 辑 
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表 4-14 给 出 了 74181 的 算术 /逻辑 运算 功能 。 

在 表 4-14 中 ,“ 十 ”表示 人 逻辑 或 运算 ,“ 加 ”表示 算术 加 运算 。M 的 值 用 来 区 别 算术 还 是 
逻辑 运算 ,S: 一 So 的 不 同 取 值 可 实现 不 同 的 操作 。 例 如 ,以 负 逻 辑 为 例 , 当 M= 王 1,Ss: 一 
S 王 1001 时 ,做 逻辑 运算 A 由 B; 当 M=0,S: 一 S% 王 1001 时 ,做 算术 运算 ,此 时 若 C= 二 0, 完 
成 A 加 B, 车 CC, 二 1, 完 成 A 加 B 加 1。 


计算 机 组 成 原理 (第 4 版 ) 


“对 一 和 属 平 半 竟 ‘V2 二 V 几 VV 当 举 * :和 改 


VY 一 立 ER 


i 
EK 


EVD | Var | ay | imvigv-4 | Viav-d 
EVD | VD | giv-a | imviav-4 | viav-da 
mVviv | MV vv | Vv 0=4 | oo 
L tf gv (g++V)=4 gvV tf(g+V)=7 oTOT 
L If gvV 性 和 一 上 vv=4 8 十 000T 


和 Y 一 习 oITL 


< 


I 
< 
| 
KK 


[OILT 


一 
| 
[en 


A 
|| 
Kk 
A 
Il 
Kk 


|< 
Il 
Kk 
A 
|< 
ll 
Kk 


[of gv f(g +V) = Gy ga 1010 

[ff gv tf V = gvV=4 g+V=4 00T0 

0 一 刁 0 一 洒 I LL00 

1 I (g+V) = gV=4 g+V=4 0T00 

1 几 (8 十 V) 一 上 g+V = gv 1000 

L lf V=4 V=4 了 一 部 V=7 0000 

(对 好 比 )0=="o (对 如 半 )1="o (T= 从) (对 和 撤 妆 )T= "oO (对 好 壮 )0="o (T= 二 共 ) 

(0 一 J) 瘟 亚 闭 划 (0 一 内) 新 型 六 新 新 型 摆 恒 (0 二 W) 间 束 六 上 (0 一 内) 商 型 六 疡 。 |。 毅 束 指 列 a 


尘 绰 性 划 束 蔚 角 /六 莫 虹 I8ItL YI 举 
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3. ALU 的 应 用 


世上 测 


74181 的 4 位 作为 一 个 小 组 ,小 组 间 既 可 以 采用 串 行进 位 ,也 可 以 采用 并 行进 位 。 当 采 
用 串 行进 位 时 ,只 要 把 低 一 片 的 C,+4 与 高 一 片 的 Pr ed 
C, 相 连 即 可 。 当 采用 组 间 并 行进 位 时 ,需要 增加 
一 片 74182 ,这 是 一 个 先行 进位 部 件 。74182 芯片 
方 框图 如 图 4-28 所 示 。74182 可 以 产生 3 个 进位 
信号 C,+。、C+ C++ 并 且 还 产生 大 组 进位 产生 
函数 G 和 进位 传递 函数 P。 Se 

图 4-29 是 由 8 片 74181 和 2 片 74182 构成 的 
32 位 两 级 行 波 ALU。 各 片 74181 输出 的 组 进位 

.> 4-28 74182 芯片 

产生 因数 G; 和 组 进位 传递 明 数 P; 作为 74182 的 
输入 ,而 74182 输出 的 进位 信号 Ch、 C++ Cn+。 
作为 74181 的 输入 ,74182 输出 的 大 组 进位 产生 了 苑 数 G 和 大 组 进位 传递 函数 P 可 作为 更 高 
一 级 74182 的 输入 。 


13 74182 


O)| 
可 | 


G P 


74182 74182 


TH HE 周全 问 |“ 丈 癌 二 HR 
G : 
32 74181 C, 74181 忆 ， 74181 EC 74181 Ci 74181 CC 74181 Ct 74181 已 74181 Co 


4-29 32 位 两 级 行 波 ALU 


74181 的 结构 适合 于 组 成 各 种 位 数 的 ALU 部 件 。 表 4-15 列 出 了 具有 不 同位 数 和 结构 
的 ALU 所 需 的 忆 片 数目 和 加 法 时 间 。 


4.9.3 浮 点 运算 器 欠 例 


目前 在 微机 系统 中 往往 配置 有 专门 的 浮 点 运算 部 件 ,例如 PC 系列 机 中 的 80x87 就 是 
浮 点 协 处 理 器 。 对 于 486SX 以 下 的 微机 ,80x87 是 任 选 件 ;而 对 于 486DX 及 其 以 上 的 微机 ， 
80x87 已 被 集成 在 CPU 芯片 中 。 


表 4-15 具有 不 同位 数 和 结构 的 ALU 


芯片 片 数 
位 数 ALU 结构 总 的 加 法 时 间 (ns) 


4 一 级 ALU 1 
8 一 级 行 波 ALU 2 
16 一 级 行 波 ALU 4 
16 两 级 ALU 4 
32 一 级 行 波 ALU 8 


OO 


OO 一 OO OO 
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续 表 
位 数 ALU 结构 总 的 加 法 时 间 (ns) 
32 两 级 行 波 ALU 2 
48 一 级 行 波 ALU 0 
48 两 级 行 波 ALU 3 
48 三 级 ALU 4 
64 一 级 行 波 ALU 0 
64 两 级 行 波 ALU 4 
64 三 级 ALU 5 


1. 80x87 的 数据 格式 


80x87 可 处 理 7 种 不 同 的 数据 类 型 ,这 些 数 据 类 型 的 格式 如 图 4-30 所 示 。 对 整数 来 
说 ,最 高 位 为 符号 位 ,用 补 码 表示 ,有 16、32 和 64 位 3 种 格式 。 压 缩 的 十 进 制 数 串 是 用 特殊 
形式 表示 的 整数 。 十 进 制 数 的 一 位 用 4 位 二 进 制 表示 ,80 位 的 低 72 位 表示 18 位 十 进 制 
数 , 最 高 位 为 符号 位 , 正 数 和 负数 都 是 以 原 码 形式 存储 的 。 浮 点 数 有 32、64 和 80 位 3 种 格 
式 , 阶 码 的 底 为 2, 用 移 码 表示 ,尾数 用 原 码 表示 。 


1514 
字 整 数 | -32 768 ~ 32 767 
0 
短 整 数 [S| SI aa | -2X10?~2X10? 
63 62 
长 整数 |S | -9X108~9X108 
罗 2 6867 4 
Se _108+1~ 1018-1 
0 22 
短 浮 点 数 |S js| | ER 8.84X10-37~ 3.37X 1038( 正 数 时 ) 
6362 52 51 
长 浮 点 数 sm Ra | 4.19X10-307~ 1.67X10308( 正 数 时 ) 
7978 ”6463 
临时 浮 点 数 SEE 3.19X10-4932 ~ 1.2X 104932 ( 正 数 时 ) 


中 4-30 ”80x87 的 数据 格式 


2. 80x87 的 内 部 结构 


图 4-31 为 80x87 的 内 部 结构 。 它 是 由 总 线 控制 逻辑 部 件 、 数 据 接口 与 控制 部 件 、 浮 点 
运算 部 件 3 个 主要 功能 模块 组 成 的 。 

在 80x87 的 浮 点 运算 部 件 中 ,分 别 设置 了 阶 码 (指数 ) 运 算 部 件 与 尾数 运算 部 件 ,并 设 有 
加 速 移 位 操作 的 移 位 器 。 它 们 通过 指数 总 线 和 尾数 总 线 与 8 个 80 位 字 长 的 寄存 器 组 相连 。 

80x87 从 主 存 取 数 或 向 主 存 写 数 时 , 均 用 80 位 的 临时 浮 点 数 与 其 他 数据 类 型 执行 自动 
转换 。 在 80x87 中 的 全 部 数据 都 以 80 位 临时 浮 点 数 的 形式 表示 。 

80x87 与 主 微 处 理 带 协同 工作 , 微 处 理 带 执行 有 折 有 的 常规 指令 ,而 80x87 只 执行 专门 的 


| 
总 线 控制 逻辑 
| 
| 


地 址 /总 线 控制 
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| 

总 线 控制 逻辑 | 数据 接口 和 控制 部 件 ， 浮 点 运算 部 件 
| | 32 数据 总 线 接口 

| 

| 


控制 字 | 16 [内 部 数据 总 线 


(数据 调整 和 操作 数 检验 ) 


”下 
指数 加 法 疾 (0) i 操作 数 寄存 需 
(16 位 ) (A 和 B) 
操作 数 B 指 才 eg 尾数 加 法 器 
宁 存 右 (16 位 ) (64 位 ) 


指数 总 线 | 寄存 器 组 栈 | 尾数 总 线 


微 程序 9 
控制 部 件 常量 ROM(44X67 位 ) 


| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
琳 存 胡 (16 位 ) 
| 
| 
| 
| 
| 
| 
| 
状 太 
状态 
| 
| 
| 


4-31 80x87 的 内 部 结构 


算术 协 处 理 器 指令 ,该 指令 称 为 换 码 (ESC) 指 令 。 微 处 理 器 和 协 处 理 器 可 以 同时 或 并 行 
行 各 自 的 指令 。 


习 题 


4-1 证 明 : 在 全 加 器 里 进位 传递 函数 P=A4,; 十 B;=A,; 中 B,。 

4-2 某 加 法 器 采用 组 内 并 行 、 组 间 并 行 的 进位 链 ,4 位 一 组 , 写 出 进位 信号 Ce 的 逻辑 表达 式 。 
4-3 设计 一 个 9 位 先行 进位 加 法 器 ,每 3 位 为 一 组 ,采用 两 级 先行 进位 线路 。 
4-4 已 知 X 和 Y, 试 用 它们 的 变形 补 码 计算 出 X 十 Y, 并 指出 结果 是 否 溢 出 。 
(1) X=0.11011, Y=0.1111]1 

(2) X=0.11011, Y=—0.10101 

(3) X 一 一 0.10110， Y= 一 0. 00001 

(4) X=—0.11011, Y=0.11110 

4-5 已 知 X 和 Y, 试 用 它们 的 变形 补 码 计算 出 X 一 Y, 并 指出 结果 是 否 溢出 。 
(1) X=0.11011, Y=—0.1111l 

(2) X=0.10111, Y=0.11011 

(3) X=0.11011, Y=—0.10011 

(4) X=—0.10110, Y= 一 0. 00001 

4-6 已 知 X=0.1011,Y== 一 0.0101。 


求 [去 X]， 4X] CX 37], [7], -23v。 


4-7 设 下 列 数 据 长 8 位 ,包括 一 位 符号 位 ,采用 补 码 表示 ,分别 写 出 每 个 数据 右 移 或 左 移 两 位 之 后 的 


结果 。 


己 地 全 吕 
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(1) 0. 1100100 

(2) 1. 0011001 

(3) 1. 1100110 

(4) 1. 0000111 

4-8 分 别 用 原 码 乘法 和 补 码 乘法 计算 XXXY。 

(1) X=0.11011, Y=—0.1111l 

(2) X=—0.11010， Y= 一 0.01110 

4-9 根据 补 码 两 位 乘法 规则 推导 出 补 码 3 位 乘法 的 规则 。 

4-10 分 别 用 原 码 和 补 码 加 减 交 蔡 法 计算 X 二 Y。 

(1) X=0.10101, Y=0.1101]1 

(2) X=—0.10101, Y=0.11011 

(3) X=0.10001, Y=—0.10110 

(4) X=—0.10110, Y=—0.11011 

4-11 已 知 :X= 一 7.25,Y==28.5625 

(1) 将 X.Y 分别 转换 成 二 进 制 浮 点 数 ( 阶 码 占 4 位 ,尾数 占 10 位 ,各 包含 一 位 符号 位 )。 

(2) 用 变形 补 码 , 求 X 一 了 Y=? 

4-12 设 浮 点 数 的 阶 码 和 尾数 部 分 均 用 补 码 表示 ,按照 浮 点 数 的 运算 规则 ,计算 下 列 各 题 ( 题 中 数字 
均 为 二 进 制 数 ) : 

(1) X=2'" X( 一 0.100010) ， Y=2'” X (一 0.111110) 

(2) X 一 2-10 X0.101100， Y=2-'™ X( 一 0. 101000) 

(3) X=2-°" X0.101100， Y=2-"!X(—0.111100) 


求 X 二 Y,X 一 了 。 
4-13 设 浮 点 数 的 阶 码 和 尾数 部 分 均 用 补 码 表示 ,按照 浮 点 数 的 运算 规则 ,计算 下 列 各 题 : 
(1) X 一 2 X 证 ， 了 一 24X (本 
求 XXY。 
(2) i Y=2X 外 
求 XY。 


4-14 用 流程 图 描述 浮 点 除法 运算 的 算法 步骤 。 

4-15 设计 一 个 一 位 5421 码 加 法 器 。 

4-16 某 计 算 机 利用 二 进 制 的 加 法 器 进行 8421 码 的 十 进 制 运算 ,采用 的 方法 是 : 

(1) 对 某 一 操作 数 预 加 6 后 ,与 另 一 操作 数 一 起 进入 二 进 制 加 法 器 。 

(2) 有 进位 产生 时 ,直接 得 到 和 的 8421 码 。 

(3) 没有 进位 时 , 反 减 6 再 得 到 和 的 8421 码 。 

试 求 十 6 、 一 6 的 校正 逻辑 。 

4-17 用 74181 和 74182 芯片 构成 一 个 64 位 的 ALU, 采 用 多 级 分 组 并 行进 位 链 ( 要 求 速 度 尽 可 
能 快 ) 。 


和 如 村 
存储 系统 和 结构 


存储 系统 是 由 几 个 容量 .速度 和 价格 各 不 相同 的 存储 天 构成 的 系统 。 设 计 一 个 容量 大 、 
速度 快 、 成 本 低 的 存储 系统 是 计算 机 发 展 的 一 个 重要 雇 题 。 本 章 重 点 讨论 主人 存储 希 的 工作 
原理 .组 成 方式 以 及 运用 半导体 存储 芯片 组 成 主 存储 天 的 一 般 原 则 和 方法 ,此 外 还 将 介绍 高 
速 缓冲 存 储 般 和 虚拟 存储 融 的 基本 原理 。 


5.1 存储 系统 的 组 成 


存储 系统 和 存储 胡 是 两 个 不 同 的 概念 。 本 节 首 先 介 绍 各 种 不 同 用 途 的 存储 副 , 然 后 介 
绍 它 们 是 如 何 构成 一 个 存储 系统 的 。 


5.1.1 存储 器 分 类 


随 看 计算 机 系统 结构 和 存储 技术 的 发 展 ,存储 帮 的 种 类 日 益 壹 多 ,根据 不 同 的 特征 可 对 
存储 副 进 行 分 类 。 


1. 按 存储 器 在 计算 机 系统 中 的 作用 分 类 


(1) 高 速 缓冲 存储 器 

高 速 缓冲 存储 器 (Cache) 位 于 主 存 和 CPU 之 间 , 用 来 存放 正在 执行 的 程序 段 和 数据 ， 
以 便 CPU 能 高 速 地 使 用 它们 。 高 速 缓冲 存储 需 的 存 取 速度 可 以 与 CPU 的 速度 相 匹 配 ,但 
存储 容量 较 小 ,价格 较 高 。 目 前 的 高 档 微 机 通常 将 它们 或 它们 的 一 部 分 制作 在 CPU 芯 
片 中 。 

(2) 主 存 储 器 

主 存 用 来 存放 计算 机 运行 期 间 所 需要 的 程序 和 数据 ,CPU 可 直接 随机 地 进行 读 / 写 访 
问 。 主 存 具 有 一 定 容 量 , 存 取 速 度 较 高 。 由 于 CPU 要 频繁 地 访问 主 存 ,所 以 主 存 的 性 能 在 
很 大 程度 上 影响 了 整个 计算 机 系统 的 性 能 。 

(3) 辅助 存储 需 

辅助 存储 器 又 称 外 存储 器 或 后 援 存储 器 , 它 用 来 存放 当前 暂 不 参与 运行 的 程序 和 数据 
以 及 一 些 需要 永久 性 保存 的 信息 。 辅 存 设 在 主机 外 部 ,容量 极 大 且 成 本 很 低 , 但 存 取 速 度 较 
低 ,而 且 CPU 不 能 直接 访问 它 。 辅 存 中 的 信息 必须 调和 人 主 存 之 后 ,CPU 才能 使 用 。 
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2. 按 存 取 方式 分 类 


(1) 随机 存 取 存储 器 (Random Access Memory,RAM) 

所 谓 随机 存 取 是 指 CPU 可 以 对 存储 器 中 的 内 容 随 机 地 和 存 取 ,CPU 对 任何 一 个 存储 单 
元 的 写 入 和 读 出 时 间 是 一 样 的 , 即 存 取 时 间 相 同 , 与 其 所 处 的 物理 位 置 无 关 。RAM 读 / 写 
方便 ,使 用 灵活 ,主要 用 作 主 存 , 也 可 用 作 高 速 缓冲 存储 天 。 

(2) 只 读 存 储 堪 (Read Only Memory,ROM) 

ROM 可 以 看 作 RAM 的 一 种 特殊 形式 ,其 特点 是 : 存储 冀 的 内 容 只 能 随机 读 出 而 不 能 
写 和 信 。 这 类 存储 融 常 用 来 存放 那些 不 能 改变 的 信息 。 由 于 信息 一 旦 写 入 存储 兹 就 固化 了 ， 
即使 断 电 , 其 写 入 的 内 容 也 不 会 丢失 ,所 以 ROM 又 称 为 固定 存储 器 。ROM 除了 存放 某 些 
系统 程序 (如 BIOS 程序 ) 外 ,还 用 来 存放 专用 的 子 程序 ,或 用 作 郴 数 发 生 硕 .字符 发 生 硕 及 
微 程 序 控制 硕 中 的 控制 存储 需 。 

(3) 顺序 存 取 存储 器 (Sequential Access Memory,SAM) 

SAM 的 存 取 方式 与 前 两 种 存储 右 完 全 不 同 。SAM 的 内 容 只 能 按 某 种 顺序 存 取 , 存 取 
时 间 的 长 短 与 信息 在 存储 体 上 的 物理 位 置 有 关 , 所 以 SAM 只 能 用 平均 存 取 时 间作 为 衡量 
存 取 速度 的 指标 。 人 磁带 机 就 是 这 样 一 类 存储 妖 。 

(4) 直接 存 取 存储 响 (Direct Access Memory,;DAM) 

DAM 既 不 像 RAM 那样 能 随机 地 访问 任 一 个 存储 单元 ,也 不 像 SAM 那样 完全 按 顺 序 
存 取 , 而 是 介 于 两 者 之 间 。 当 要 存 取 所 需 的 信息 时 ,第 一 步 下 接 指 加 整个 存储 需 中 的 某 个 小 
区 域 ( 如 磁盘 上 的 磁道 ); 第 二 步 在 小 区 域内 顺序 检索 或 等 待 , 直 至 找到 目的 地 后 再 进行 读 / 
写 操 作 。 这 种 存储 器 的 存 取 时 间 也 是 与 信息 所 在 的 物理 位 置 有 关 的 ,但 比 SAM 的 存 取 时 
间 要 短 。 磁 盘 机 就 属于 这 类 存储 天 。 

由 于 SAM 和 DAM 的 存 取 时 间 都 与 存储 体 的 物理 位 置 有 关 , 所 以 又 可 以 把 它们 统称 
为 串 行 访问 存储 需 。 


3. 按 存储 介质 分 类 


(1) 磁 世 存储 需 

采用 具有 和 矩形 磁 浪 回 线 的 铁 氧 体 磁性 材料 ,利用 两 种 不 同 的 剩 磁 状态 表示 “1” 或 “0”。 
一 颗 磁 沪 存 放 一 个 二 进 制 位 ,成 千 上 万 颗 磁 沪 组 成 磁 芒 体 。 磁 蕊 存储 器 的 特点 是 信息 可 以 
长 期 存储 ,不 会 因 断 电 而 丢失 ;但 磁 芯 存储 器 的 读 出 是 破坏 性 读 出 , 即 不 论 磁 芯 原 存 的 内 容 
为 “0” 还 是 *1”, 读 出 之 后 磁 改 的 内 容 一 律 变 为 “0”, 因 此 需要 青 重 写 一 次 ,这 就 额外 地 增加 了 
操作 时 间 。 从 20 世纪 50 年 代 开 始 , 磁 芯 存储 需 曾 一 度 成 为 主 存 的 主要 存储 介质 ,但 因 磁 必 
存储 器 容量 小 .速度 慢 、 体 积 大 可靠 性 低 , 从 20 世纪 70 年 代 开 始 , 已 经 被 半导体 存储 器 逐 
渐 取 代 。 

(2) 半导体 存储 器 

采用 半导体 器 件 制造 的 存储 器 ,主要 有 MOS 型 存储 器 和 双 极 型 (TTL 电路 或 ECL 电 
路 ) 存 储 希 两 类 。MOS 型 存储 需 具 有 集成 度 高 、 功 耗 低 、 价 格 便宜 、. 存 取 速 度 较 慢 等 特点 ; 双 
极 型 存储 器 具有 存 取 速度 快 、 集 成 度 较 低 、 功 耗 较 大 、 成 本 较 高 等 特点 。 半 导体 RAM 存储 
的 信息 会 因为 断 电 而 丢失 。 
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(3) 磁 表 面 存 储 关 

在 金属 或 塑料 基体 上 , 涂 履 一 层 磁 性 材料 ,用 磁 层 存储 信息 ,常见 的 有 磁盘 、 磁 带 等 。 由 
于 它 的 容量 大 、 价 格 低 、. 存 取 速 度 慢 , 故 多 用 作 辅 助 存储 器 。 

(4) 光 存 储 器 

采用 激光 技术 控制 访问 的 存储 器 ,一 般 分 为 只 读 式 ,一 次 写 入 式 、 可 改写 式 3 种 ,它们 的 
存储 容量 都 很 大 ,是 目前 使 用 非常 广泛 的 辅助 存储 器 。 


4. 按 信息 的 可 保存 性 分 类 


断 电 后 存储 信息 即 消失 的 存储 副 称 为 易 失 性 存储 大 ,例如 半导体 RAM。 上 断 电 后 信息 仍然 
保存 的 存储 器 称 为 非 易 失 性 存储 器 ,例如 ROM、 磁 芯 存 储 器 、 磁 表面 存储 器 和 光 存 储 器 。 

如 果 某 个 存储 单元 所 存储 的 信息 被 读 出 时 , 原 存 信息 将 被 破坏 , 则 称 破坏 性 读 出 ;如 果 
谈 出 时 ,被 读 单 元 原 存 信息 不 被 破坏 , 则 称 非 破坏 性 读 出 。 具 有 破坏 性 读 出 性 能 的 存储 天 ， 
每 当 一 次 读 出 操作 之 后 ,必须 紧 接 一 个 重 写 (再 生 ) 的 操作 ,以 便 恢 复 被 破坏 的 信息 。 

从 原理 上 讲 , 只 要 具有 两 种 明显 稳定 的 物理 状态 的 大 件 和 介质 都 能 用 来 存储 二 进 制 信 
恩 , 但 真正 能 用 来 做 存储 大 的 硕 件 和 介质 还 需要 满足 各 类 存储 带 技 术 指 标的 要 求 。 


5.1.2 存储 系统 层次 结构 


为 了 解决 存储 容量 存 取 速度 和 价格 之 间 的 矛盾 ,通常 把 各 种 不 同 存储 容量 .不 同 存 取 
速度 的 存储 器 按 一 定 的 体系 结构 组 织 起 来 ,形成 一 个 统一 整体 的 存储 系统 。 

多 级 存储 层次 如 图 5-1 所 示 。 从 CPU 的 角度 来 看 ,n 种 不 同 的 存储 器 (Mi 一 M,) 在 逻 
辑 上 是 一 个 整体 。 其 中 ,Mi 速度 最 快 、 容 量 最 小 ,位 价格 最 高 ;MM 速度 最 慢 、 容 量 最 大 ,位 价 
格 最 低 。 整 个 存储 系统 具有 接近 于 M 的 速度 ,相等 或 接近 M, 的 容量 ,接近 于 M, 的 位 价 
格 。 在 多 级 存储 层次 中 ,最 和 常用 的 数据 在 Mi 中 ,次 常用 的 在 M; 中 ,最 少 使 用 的 在 M, 中 。 


| 存储 层次 | 

| | 
可 | 加- 匡 一- 人 
| 


图 5-1 多 级 存储 层次 


对 于 由 M 和 M; 构成 的 两 级 存储 层次 结构 ,假设 Mi、M; 访问 时 间 分 别 为 Ta 、TA: 。 
命中 率 互 定义 为 CPU 产生 的 逻辑 地 址 能 在 Mi 中 访问 到 的 概率 。 在 一 个 程序 执行 期 
间 , 设 Ni 为 访问 Mi 的 次 数 ,N 为 访问 Ms 的 次 数 , 则 命中 率 万 为 : 


不 命中 率 或 失效 率 是 指 由 CPU 产生 的 逻辑 地 址 在 M 中 访问 不 到 的 概率 。 对 于 两 级 
存储 层次 ,失效 率 为 1 一 互 。 

两 级 存储 层次 的 等 效 访问 时 间 Ts 根据 Ms 的 启动 时 间 有 : 

假设 M 访问 和 M; 访问 是 同时 局 动 的 ,大 三 瓦 XTA 十 (1 一 瓦 ) XTA; 。 

假设 M 不 命中 时 才 启 动 M: ,T= 一 HXTa 十 一 了 X(Ta 二 Tw)==Ta 二 (1 一 H)XTw。 
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存储 层次 的 访问 效率 : 


由 高 速 缓冲 存储 器 、 主 存储 器 、 辅 助 存储 器 构成 的 三 级 存储 系统 可 以 分 为 两 个 层次 ,其 
中 高 速 缓存 和 主 存 间 称 为 Cache- 主 存 存 储 层 次 (Cache 存储 系统 ) ,如 图 5-2(a) 所 示 ; 主 存 和 
辅 存 间 称 为 主 存 - 辅 存 存储 层次 (虚拟 存储 系统 ) ,如 图 5-2(b) 所 示 。 


辅助 硬件 辅助 软 硬 件 


5-2 两 种 存储 层次 


Cache 存储 系统 是 为 解决 主 存 速度 不 足 而 提出 来 的 。 在 Cache 和 主 存 之 间 ,增加 辅助 
便 件 ,让 它们 构成 一 个 整体 。 从 CPU 看 ,速度 接近 Cache 的 速度 ,容量 是 主 存 的 容量 ,每 位 
价格 接近 于 主 存 的 价格 。 巾 于 Cache 存储 系统 全 部 用 硬件 来 调度 ,因此 它 对 系统 程序 员 和 
应 用 程序 员 都 是 透明 的 。 

虚拟 存储 系统 是 为 解决 主 存 容量 不 足 而 提出 来 的 。 在 主 存 和 辅 存 之 间 ,增加 辅助 的 软 
便 件 ,让 它们 构成 一 个 整体 。 从 CPU 看 ,速度 接近 主 存 的 速度 ,容量 是 虚拟 的 地 址 空间 ,每 
位 价格 接近 于 辅 存 的 价格 。 由 于 虚拟 存储 系统 需要 通过 操作 系统 来 调度 ,因此 对 系统 程序 
员 是 不 透明 的 ,但 对 应 用 程序 员 是 透明 的 。 


5.2 主 存储 希 的 组 织 
主 存储 器 是 整个 存储 系统 的 核心 , 它 用 来 存放 计算 机 运行 期 间 所 需要 的 程序 和 数据 ， 
CPU 可 直接 随机 地 对 它 进 行 访 问 。 
S.2.1 主 存 储 器 的 基本 结构 


主 存 通 常 由 存储 体 、 地 址 译 码 (address decoding) 驱 动 电 路 .1/O 和 读 写 电路 组 成 ,其 组 
成 框图 如 图 5-3 所 示 。 


读 写 控 制 线 


5-3” 主 存 的 组 成 框图 
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存储 体 是 主 存储 大 的 核心 ,程序 和 数据 都 存放 在 存储 体 中 。 

地 址 详 码 驱动 电路 实际 上 包含 译 码 副 和 驱动 带 两 部 分 。 译 人 码 帮 将 地 址 总 线 输入 的 地 址 
码 转 换 成 与 之 对 应 的 译 码 输出 线 上 的 有 效 电 平 ,以 表示 选中 了 茶 一 存储 单元 ,然后 由 驱动 帮 
提供 驱动 电流 去 驱动 相应 的 读 写 电 路 ,完成 对 被 选中 存储 单元 的 读 写 操作 。 

1/O 和 读 写 电路 包括 读 出 放大 带 、 写 入 电路 和 读 写 控制 电路 ,用 以 完成 被 选中 存储 单元 
中 各 位 的 读 出 和 写 入 操作 。 

主 存 的 读 写 操作 是 在 控制 需 的 控制 下 进行 的 ,只 有 接收 到 来 自控 制 硕 的 读 写 命令 或 写 
允许 信号 后 ,才能 实现 正确 的 读 写 操作 。 


5.2.2 主 存储 器 的 存储 单元 


位 是 二 进 制 数 的 最 基本 单位 ,也 是 存储 器 存储 信息 的 最 小 单位 。 一 个 二 进 制 数 巾 若干 
位 组 成 , 当 这 个 二 进 制 数 作 为 一 个 整体 存 人 或 取出 时 ,这 个 数 称 为 存储 字 。 存 放 存 储 字 或 存 
储 字 节 的 主 存 空间 称 为 存储 单元 或 主 存单 元 ,大 量 存储 单元 的 集合 构成 一 个 存储 体 ,为 了 区 
别 存储 体 中 的 各 个 存储 单元 ,必须 将 它们 逐一 编号 。 存 储 单元 的 编号 称 为 地 址 ,地 址 和 存储 
单元 之 间 有 一 对 一 的 对 应 关系 ,就 像 一 座 大 楼 的 每 个 房间 都 有 房间 号 一 样 。 

一 个 存储 单元 可 能 存放 一 个 字 ,也 可 能 存放 一 个 字 节 ,这 是 由 计算 机 的 结构 确定 的 。 对 
于 字 节 编 址 的 计算 机 ,最 小 寻 址 单位 是 一 个 字 节 , 相 邻 的 存储 单元 地 址 指 癌 相 邻 的 存储 字 
节 ; 对 于 字 编 址 的 计算 机 ,最 小 寻 址 单位 是 一 个 字 , 相 邻 的 存储 单元 地 址 指向 相 邻 的 存储 字 。 
所 以 ,存储 单元 是 CPU 对 主 存 可 访问 操作 的 最 小 存储 单位 。 

例如 ,IBM 370 机 是 字 长 为 32 位 的 计算 机 , 主 存 按 字 节 编 址 ,每 一 个 存储 字 包 含 4 个 单 
独 编 址 的 存储 字 节 ,其 地 址 安排 如 图 5-4(a) 所 示 。 它 被 称 为 大 端 (big-endian) 方 案 , 即 字 地 
址 等 于 最 高 有 效 字 节 地 址 , 且 字 地 址 总 是 等 于 4 的 整数 倍 , 正 好 用 地 址 码 的 最 末 两 位 来 区 分 
同一 个 字 的 4 个 字 节 。PDP-11 机 是 字 长 为 16 位 的 计算 机 , 主 存 也 按 字 节 编 址 ,每 一 个 存储 
字 包 含 2 个 单独 编 址 的 存储 字 节 ,其 地 址 安排 如 图 5-4(b) 所 示 。 它 被 称 为 小 端 (little- 
endian) 方 案 , 即 字 地 址 等 于 最 低 有 效 字 节 地 址 , 且 字 地 址 总 是 等 于 2 的 整数 倍 , 正 好 用 地 址 
码 的 最 末 一 位 来 区 分 同一 个 字 的 2 个 字 节 。 从 图 5-4 可 以 看 出 ,大 端 方案 从 最 高 有 效 字 节 
回 最 低 有 效 字 节 进 行 字 节 地 址 编号 ,小 端 方案 从 最 低 有 效 字 节 回 最 高 有 效 字 节 进 行 字 节 地 
址 编号 。 


字 字 

和 字 节 地 址 地 字 节 地 址 

0 0 | 1 | 2 3 0 1 0 
4| 4 | 5 | 6 2 
83s | 9 | 1 | 1 4 


5-4” 字 节 编 址 计算 机 的 地 址 安排 方案 


采用 大 、 小 端 方案 对 数据 进行 存放 的 主要 区 别 在 于 存放 的 字 节 顺序 ,如 果 将 一 个 32 位 
的 整数 0x12345678 存放 到 一 个 整 型 变量 (int) 中 ,这 个 整 型 变量 采用 大 端 或 者 小 端 方案 在 
主 存 中 的 存放 如 表 5-1 所 示 ( 假 设 从 地 址 0x4000 开始 存放 ) 。 
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表 5-1 32 位 整 型 变量 存放 方案 


主 存 地 址 大 端 方 案 小 端 方案 


0x4000 12( MSB) 78(LSB) 
0x4001 34 50 
0x4002 50 34 
0x4003 78(LSB) 12( MSB) 


从 表 5-1 可 以 看 出 ,大 端 方案 将 高 字 节 (MSB) 存 放 在 低地 址 ,小 端 方案 将 高 字 节 存放 
在 高 地 址 。 采 用 大 端 方案 进行 数据 存放 符合 人 类 的 正常 思维 ,而 采用 小 端 方案 进行 数据 
存放 利于 计算 机 处 理 。 到 目前 为 止 , 采 用 大 端 或 者 小 端 进行 数据 存放 ,其 熟 优 热 劣 也 没 
有 定论。 大 端 方 案 与 小 端 方案 的 差别 体现 在 一 个 处 理 大 的 寄存 需 、 指 令 集 、 数据 总 线 等 
各 个 层次 中 。 

Intel 80x86 采用 小 端 方案 ,IBM 370、Motorola 680x0 和 大 多 数 RISC 机 器 则 采用 大 端 
方案 。 有 些微 处 理 需 ,如 Power PC, 既 文 持 大 端 方 案 又 文 持 小 端 方 案 , 在 心 片 加 电 启 动 时 只 
要 选择 确定 即 可 (默认 为 大 端 方 案 , 可 选择 小 端 方案 ) 。 

在 排序 顺序 不 同 的 系统 之 间 进 行 数据 通信 时 ,需要 进行 顺序 转换 。 了 解 字 节 顺 序 的 好 
处 在 于 调试 底层 机 器 级 程序 时 ,能够 清楚 每 个 数据 的 字 节 顺序 ,以 便 将 一 个 机 器 数 正 确 转 化 
为 真 值 。 


5.2.3 主 存储 器 的 主要 技术 指标 
1. 存储 容量 


对 于 字 节 编 址 的 计算 机 ,以 字 节 数 来 表示 存储 容量 ;对 于 字 编 址 的 计算 机 ,以 字数 与 其 
字 长 的 乘积 来 表示 存储 容量 。 例 如 , 某 计算 机 的 主 存 容量 为 64K X16, 表 示 它 有 64K 个 存 
储 单元 ,每 个 存储 单元 的 字 长 为 16 位 ,在 改 用 字 节 数 表 示 , 则 可 记 为 128K 字 节 ( 即 
128KB) 。 


2. 存 取 速 度 


主 存 的 存 取 速度 通常 由 存 取 时 间 T, 、 存 取 周 期 T, 和 主 存 带 宽 B, 等 参数 来 描述 。 

(1) 存 取 时 间 了 

存 取 时 间 又 称 为 访问 时 间或 读 写 时 间 , 它 是 指 从 局 动 一 次 存储 器 操作 到 完成 该 操作 所 
经 历 的 时 间 。 例 如 , 读 出 时 间 是 指 从 CPU 向 主 存 发 出 有 效 地 址 和 读 命 令 开 始 ,直到 将 被 选 
单元 的 内 容 读 出 为 止 所 用 的 时 间 ; 写 入 时 间 是 指 从 CPU 回 主 存 发 出 有 效 地 址 和 写 命 令 开 
始 ,直到 信息 写 人 被 选中 单元 为 止 所 用 的 时 间 。 显 然 ,T, 越 小 , 存 取 速度 越 快 。 

(2) 存 取 周期 T。 

存 取 周期 又 称 读 写 周期 \ 访 存 周期 ,是 指 主 存 进行 一 次 完整 的 读 写 操作 所 需 的 全 部 时 
间 , 即 连续 两 次 访问 存储 器 操作 之 间 所 需要 的 最 短 时 间 。 显 然 ,一 般 情况 下 ,T, 宝 T,。 这 是 
因为 对 于 任何 一 种 存储 器 ,在 读 写 操 作 之 后 ,总 要 有 一 段 恢 复 内 部 状态 的 复原 时 间 。 对 于 破 
坏 性 读 出 的 RAM, 存 取 周 期 往往 比 存 取 时 间 要 大 得 多 ,甚至 可 以 达到 T, 二 2T, ,这 是 因为 存 
储 需 中 的 信息 读 出 后 需要 马上 进行 重 写 ( 再 生 ) 。 


疗 储 系统 和 结构 


(3) 主 存 市 宽 B。 

与 存 取 周期 密切 相关 的 指标 是 主 存 的 带宽 , 它 又 称 为 数据 传输 率 , 表 示 每 秒 从 主 存 进出 
信息 的 最 大 数量 ,单位 为 字 每 秒 或 字 节 每 秒 或 位 每 秒 。 主 存 带 宽 与 主 存 的 等 效 工 作 频 率 及 
主 存 位 宽 有 关系 , 奉 单位 为 字 节 每 秒 , 则 有 : 

B。 二 主 存 等 效 工 作 频 率 X 主 存 位 宽 二 8 

目前 , 主 存 提 供 信息 的 速度 还 跟 不 上 CPU 处 理 指令 和 数据 的 速度 ,所 以 , 主 存 的 带宽 
是 改善 计算 机 系统 瓶颈 的 一 个 关键 因素 。 为 了 提高 主 存 的 带宽 ,可 以 采取 的 措施 有 

。 缩短 存 取 周 期 。 

。 增加 存储 字 长 。 

。 增加 存储 体 。 


3. 可靠 性 


可 靠 性 是 指 在 规定 的 时 间 内 ,存储 硕 无 故障 谈 写 的 概率 。 通 篆 , 用 平均 故障 间隔 时 间 
(Mean Time Between Failures, MTBF) 来 衡量 可 徘 性 。MTBF 越 长 ,说明 存 储 需 的 可 徘 性 


功 耗 是 一 个 不 可 忽视 的 问题 , 它 反映 了 存储 天 件 耗 电 的 多 少 ,同时 也 反映 了 其 发 热 的 程 
度 。 通 稼 布 望 功 耗 要 小 ,这 对 存储 需 件 的 工作 稳定 性 有 好 处 。 大 多 数 半导体 存储 套 的 工作 
功 耗 与 维持 功 耗 是 不 同 的 ,后 者 大 大 地 小 于 前 者 。 


5.2.4 数据 在 主 存 中 的 存放 


目前 ,大 多 数 存 储 器 采用 字 节 编 址 ,数据 在 主 存 中 有 3 种 不 同 存放 方法 ,如 图 5-5 所 示 。 
设 存 储 字 长 为 64 位 (8 个 字 节 ), 即 一 个 存 取 周期 最 多 能 够 从 主 存 读 或 写 64 位 数据 。 图 5-5 
中 最 左边 一 列表 示 字 地 址 (十 六 进 制 ) , 字 地 址 的 最 末 3 个 二 进 制 位 必定 为 000。 假 设 读 写 
的 数据 有 4 种 不 同 长 度 , 它 们 分 别 是 字 节 (8 位 )、 半 字 (16 位 ) 单字 (32 位 ) 和 双 字 (64 位 )。 

注意 : 此 例 中 数据 字 长 (32 位 ) 不 等 于 存储 字 长 (64 位 )。 

图 5-5(a) 是 一 种 不 瀛 费 存 储 右 资源 的 存放 方法 ,4 种 不 同 长 度 的 数据 一 个 紧 接 者 上 一 
个 存放 。 这 种 数据 存放 方式 的 优点 是 不 浪费 宝贵 的 主 存 资 源 。 但 是 存在 问题 ,主要 问题 有 
两 个 : 一 是 除了 访问 一 个 字 节 以 外 , 当 要 访问 一 个 双 字 ,一 个 单字 或 一 个 半 字 时 都 有 可 能 需 
要 花费 两 个 存 取 周期 ,因为 从 图 5-5(a) 中 可 以 看 出 ,一 个 双 字 ,一 个 单字 或 一 个 半 字 都 有 可 
能 跨越 两 个 存储 字 存 放 , 这 使 存储 器 的 工作 速度 降低 了 一 半 ; 二 是 存储 器 的 读 写 控制 比较 

为 了 克服 上 述 两 个 缺点 ,出 现 了 图 5-5(b) 所 示 的 男 一 种 数据 存放 方法 。 这 种 存放 方法 
规定 ,无 论 要 存放 的 是 字 节 、 半 字 .单字 或 双 字 ,都 必须 从 一 个 存储 字 的 起 始 位 置 开 始 存 放 
(在 图 5-5(b) 中 是 从 最 左边 放 起 ) ,而 多 余 的 部 分 浪费 不 用 。 这 种 数据 存放 方法 的 优点 是 : 
无 论 访问 一 个 字 节 .一 个 半 字 .一 个 单字 或 一 个 双 字 都 可 以 在 一 个 存储 周期 内 完成 , 读 写 数 
据 的 控制 比较 简单 。 但 它 的 主要 缺点 是 浪费 了 宝贵 的 存储 需 资 源 ,如 果 双 字 .单字 . 半 字 . 字 
节 4 种 不 同 长 度 的 数据 出 现 的 概率 相同 的 话 , 那 么 主 存 的 实际 利用 率 只 有 约 50% , 即 有 一 
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… xx00H a 40 位 ) 
| 双子 (所 24 位 ) 半 | 
… xx10H 单字 (前 16 位 ) 


.… XX18H 和 16 位 ) 采信 用 


64 位 (8 个 字 节 ) 
(a) 


I 
… xx08H 一 DR 
lO EE 
I II I 
... xx20H 
... xx28H dD 
… xx30H | 
… XxX38H II GI 


人 
(b) 


... xx00H EE III III 


NS 


…xXx08H 
... xx10H 
“ll 
We 


64 位 (8 个 字 贡 ) 
(5) 


图 5-5 字 节 编 址 的 主 存储 器 的 各 种 存放 方法 


半 的 存储 空间 被 浪费 。 

综合 前 两 种 数据 存放 方法 的 优 缺 点 ,出 现 了 如 图 5-5(c) 所 示 的 折 中 方案 。 图 5-5(Cc) 所 
示 的 存放 方法 规定 , 双 字 数据 (8 个 字 节 ) 的 起 始 地 址 的 最 末 3 个 二 进 制 位 必须 为 000(8 的 
整 倍数 ) ,单字 数据 (4 个 字 节 ) 的 起 始 地 址 的 最 末 两 位 必须 为 00(4 的 整 倍数 ) , 半 字 数据 
(2 个 字 节 ) 的 起 始 地 址 的 最 末 一 位 必须 为 0( 偶 数 )。 这 种 存储 方式 能 够 保证 无 论 访问 双 字 、 
单字 . 半 字 或 字 节 ,都 能 在 一 个 存 取 周 期 内 完成 ,尽管 存储 器 资源 仍然 有 浪费 ,但 是 比 图 5-5 
(b) 所 示 的 存放 方法 要 好 得 多 。 这 种 存放 方法 被 称 为 边界 对 齐 的 数据 存放 方法 。 


5.3 半导体 随机 存储 怖 和 只 恋 存 储 希 


主 存储 硕 通 篆 分 为 RAM 和 ROM 两 大 部 分 。RAM 可 读 可 写 ,ROM 只 能 读 不 能 写 。 
下 面 重点 介绍 RAM 的 工作 原理 与 结构 ,以 及 ROM 的 基本 类 型 。 


5.3.1 RAM 记忆 单元 电路 


通常 把 存放 一 个 二 进 制 位 的 物理 器 件 称 为 记忆 单元 , 它 是 存储 右 的 最 基本 构件 ,地 址 码 
相同 的 多 个 记忆 单元 构成 一 个 存储 单元 。 记 忆 单 元 可 以 由 各 种 材料 制 成 ,但 最 常见 的 由 
MOS 电路 组 成 。RAM 又 可 分 为 静态 RAM(Static RAM,SRAM) 和 动态 RAM (Dynamic 
RAM,DRAM) 两 种 。 
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1. 6 管 SRAM 记忆 单元 电路 


6 管 SRAM 记忆 单元 电路 如 图 5-6 所 示 。 

SRAM 记忆 单元 是 用 双 稳 态 触发 器 来 记忆 信息 的 ， Vcc 
从 图 5-6 中 可 以 看 出 ,T 一 Ts 管 构成 一 个 记忆 单元 的 主 
体 ,能 存放 一 位 二 进 制 信息 。 其 中 ,Ti 和 T; 管 构成 存储 
信息 的 双 稳 态 触 发 器 ;T: 和 T, 管 构成 门 控 电路 ,控制 读 
写 操作 ;Ts 和 Te 是 Ti 和 T: 管 的 负载 管 。 电 路 中 有 一 条 
字 线 ,用 来 选择 这 个 记忆 单元 ,还 有 两 条 位 线 , 用 来 传送 
读 写 信号。 位 线 1/O 字 线 位 线 TO 

假定 : T, 管 截止 `.T: 管 导 通 (A=1、B=0) 表 示 该 记 图 5-6 6 管 SRAM 记忆 单元 电路 
忆 单 元 中 存储 的 是 “1 信息 ;Ti; 管 导 通 、T: 管 截止 (A 王 0、 

B 王 1) 表 示 该 记忆 单元 中 存储 的 是 “0 信息 。 

当 字 线 为 低 电 平时 ,该 记忆 单元 未 被 选中 ,T: 和 T, 管 截止 ,触发 器 与 位 线 隔 开 , 原 存 信 
息 不 会 改变 , 称 为 保持 状态 。 

当 字 线 为 高 电 平时 ,该 记忆 单元 被 选中 ,Ts 和 T, 管 导 通 ,可 进行 读 写 操作 。 位 线 I/O 被 
称 为 读 写 “1” 线 ,位 线 1/O 被 称 为 读 写 “0” 线 。 

读 操 作 : 因为 T; 和 T, 管 导 通 ,相当 于 A 点 和 B 点 分 别 与 位 线 1/O 和 LI/O 相 连 。 若 记忆 
单元 原 存 “1”, 则 1/O 线 输出 高 电 平 ,1/O 线 输出 低 电 平 ,完成 读 “1” 操 作 ; 若 记忆 单元 原 存 
“0”, 则 I/O 线 输 出 低 电 平 ,I/O 线 输出 高 电 平 ,完成 读 “0” 操 作 。 

写 操作 : 如 果 要 写 人 “1”, 则 在 I/O 线 上 输入 高 电 平 ,I/O 线 上 输入 低 电 平 ,它们 将 分 别 
通过 T; 和 T, 管 迫使 T 管 截止 .T: 管 导 通 ,该 记忆 单元 内 容 成 为 "1”, 完 成 写 "1? 操 作 ; 如 果 
要 写 人 “0”, 则 在 I/O 线 上 输入 低 电 平 ,1/O 线 输入 高 电 平 ,经 过 同样 的 路 径 迫 使 T 管 导 通 、 
T; 管 截止 ,该 记忆 单元 内 容 成 为 “0”, 完 成 写 “0” 操 作 。 

在 该 记忆 单元 未 被 选中 或 读 出 时 ,电路 处 于 双 稳 态 触发 器 工作 状态 ,由 电源 Vcc 不 断 给 
Ti 和 人 本, 管 供电 ,以 保存 信息 。 但 是 ,只 要 电源 被 切断 ,原来 的 保存 信息 便 会 丢失 ,这 就 是 半 
导体 存储 器 的 易 失 性 。 

SRAM 的 存 取 速度 快 ,但 集成 度 低 , 功 耗 也 较 大 ,所 以 一 般 用 来 组 成 高 速 缓 冲 存储 器 和 
小 容量 主 存 系统 。 


2. 4 管 DRAM 记忆 单元 电路 


如 果 将 前 述 6 管 SRAM 记忆 单元 电路 中 的 两 个 负载 管 (T; 和 Te ) 去 掉 , 便 形成 4 管 
DRAM 记忆 单元 电路 ,如 图 5-7 所 示 。 负 载 回路 断 开 后 ,保持 状态 时 没有 外 加 电源 供电 , 因 
而 Ti 和 T: 管 不 再 构成 双 稳 态 触发 硕 , 所 以 动态 MOS 记忆 单元 是 徘 MOS 电路 中 的 栅 极 电 
容 C1 和 Cs 来 存储 信息 的 。 

图 5-7 中 虚线 框 外 的 两 个 MOS 管 是 公用 的 预 充 管 ,不 算 在 记忆 单元 电路 中 。 

假定 : C, 上 有 电荷 (高 电 平 ) \、Cy 上 无 电荷 ( 低 电 平 ) 时 ,表示 存储 "12 信息 :Cs* 上 无 电荷 
( 低 电 平 ) \Cy 上 有 电荷 (高 电 平 ) 时 ,表示 存储 “0” 信 息 。 由 于 MOS 管 栅 极 的 输入 电阻 很 大 ， 
所 以 栅 极 泄漏 电流 很 小 ,即使 没有 负载 管 的 供电 , 栅 极 电容 上 的 电荷 也 能 保存 相当 一 段 时 
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间 。 然 而 , 栅 极 电容 上 的 电荷 数目 毕竟 是 有 限 的 ,虽然 释放 速度 很 慢 , 但 经 过 一 段 时 间 后 仍 
然 会 使 记忆 单元 中 存储 的 信息 丢失 ,因此 每 隔 一 定 的 时 间 必 须 向 栅 极 电容 补充 一 次 电荷 ,这 
个 过 程 称 为 “刷新 ”。 

平时 记忆 单元 处 于 保持 状态 , 字 线 为 低 电 平 , 原 存 的 信息 被 存储 在 Ti 和 T: 管 的 栅 极 分 
布 电容 Ci 或 Cs 上 , 栅 极 的 泄漏 电流 使 存储 的 信息 能 保留 几 毫 秒 。 

写 人 时 , 字 线 为 高 电 平 ,打开 选 通 门 T;: 和 T,。 如 果 写 “1”, 在 1/0O 线 上 输入 高 电 平 ,I/O 
线 上 输入 低 电 平 ,使 C, 充 电 、Ci 放 电 ; 如 果 写 “0”, 在 1/0 线 上 输入 低 电 平 ,W/O 线 上 输入 高 电 
平 ,使 Ci 充电 、C; 放 电 。 

读 出 时 , 预 充 电信 号 先 打开 预 充 管 , 使 位 线 1/O 和 1/O 均 成 为 高 电 平 。 当 选中 记忆 单元 
后 , 选 通 门 被 打开 , 若 原 存 “1”, 则 Cs 上 有 电荷 ,Ts 导 通 ,使 1/O 线 上 有 人 负 脉冲 输出 , 读 出 “1”; 
右 原 存 “0”, 则 Cy 上 有 电荷 ,Ti 导 通 ,使 IO 线 上 有 负 脉 冲 输 出 , 读 出 "07”。 在 读 出 过 程 中 , 电 
源 还 通过 I/O 或 IO 线 分 别 向 Cs 或 Ci 补充 电荷 。 

4 管 DRAM 记忆 单元 的 刷新 过 程 也 是 对 栅 极 电容 Ci 或 C; 补 充电 荷 的 过 程 ,因此 刷新 
过 程 也 就 是 读 出 过 程 , 只 是 这 种 读 出 的 目的 不 是 为 了 从 1/O 线 或 IO 线 上 得 到 读 出 信息 ,而 
是 为 了 对 记忆 单元 进行 刷新 操作 , 常 将 其 称 作 “ 假 读 ”。 

DRAM 集成 度 高 , 功 耗 小 ,但 存 取 速度 慢 ,一般 用 来 组 成 大 容量 主 存 系统 。 


3. 单 管 DRAM 记忆 单元 电路 


一 步 减 少 记 忆 单 元 中 MOS 管 的 数目 可 形成 更 简单 的 3 管 DRAM 记忆 单元 或 单 管 

DRAM 记忆 单元 。 这 里 仅 介绍 单 管 DRAM 记忆 单元 ， gp 5-8 所 示 。 

从 图 5-8 中 可 看 出 , 单 管 动态 记忆 单元 由 一 个 MOS 管 一 个 存储 电容 C 构成 。 

当 字 线 为 高 电 平 时 ,该 电路 被 选中 。 位 线 

写 和 人 时 ,特写 人 “1?”, 位 线 为 高 电 平 ,对 电容 C 充电 ;大写 入 
“0”, 位 线 为 低 电 平 ,C 上 的 电荷 经 位 线 泄 放 。 

读 出 时 , 耕 原 存 “"1”,C 上 有 电荷 ,经 Ti; 管 在 位 线 上 产生 读 电 
流 ,完成 读 “12? 操 作 ; 若 原 存 “0”,C 上 无 电荷 ,在 位 线 上 不 产生 读 
电流 ,完成 读 “0” 操 作 。 当 读 操作 完毕 ,存储 电容 C 上 的 电荷 已 被 
汇 放 完 , 故 是 破坏 性 读 出 ,必须 采取 重 写 (再 生 ) 的 措施 。 5-8 单 管 DRAM 记忆 

存储 电容 C 的 容量 不 可 能 做 得 很 大 ,一般 比 位 线 上 的 寄生 电 单元 电路 
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容 C4 还 要 小 。 在 读 出 时 ,人 耳 导 通 后 ,电荷 将 在 C 和 Ca 间 分 配 ,就 会 使 读 出 信息 减 小 ,所 以 ， 
用 单 管 记忆 单元 组 成 的 存储 器 中 , 读 出 放大 器 应 有 较 高 的 灵敏 度 。 因 为 信息 是 存储 在 一 个 
很 小 电容 C 上 ,也 只 能 保留 几 毫 秒 的 时 间 ,所 以 必须 定时 地 进行 刷新 操作 。 

显然 , 单 管 DRAM 记忆 单元 与 4 管 DRAM 记忆 单元 比较 ,具有 功 耗 更 小 、 集 成 度 更 高 
的 优点 。 


5.3.2 动态 RAM 的 刷新 


国 尼 


1. 刷新 间隔 


前 面 已 经 说 过 ,为 了 维持 DRAM 记忆 单元 的 存储 信息 ,每 隔 一 定时 间 必 须 刷新 。 那 么 
每 隔 多 少时 间 进 行 一 次 刷新 操作 呢 ? 这 主要 是 根据 栅 极 电容 上 电 三 的 汇 放 速度 来 决定 的 。 
一 般 选 定 的 最 大 刷新 间隔 为 2ms 或 4ms 甚至 更 大 ,也 就 是 说 ,应 在 规定 的 时 间 内 ,将 全 部 存 
储 体 刷新 一 过 。 

注意 : 刷新 和 重 写 (再 生 ) 是 两 个 完全 不 同 的 概念 , 切 不 可 混 消 。 重 写 是 随机 的 , 某 个 存 
储 单 元 只 有 在 破坏 性 读 出 之 后 才 需 要 重 写 。 而 刷新 是 定时 的 ,即使 许多 记忆 单元 长 期 未 被 
访问 , 若 不 及 时 补充 电荷 的 话 , 信 息 也 会 丢失 。 重 写 一 般 是 按 存储 单元 进行 的 ,而 刷新 通 种 
是 以 存储 体 和 矩阵 中 的 一 行为 单位 进行 的 。 


2. 刷新 方式 


常见 的 刷新 方式 有 和 集中 式 、 分 散 式 和 异步 式 3 种 。 

(1) 集中 刷新 方式 

在 允许 的 最 大 刷新 间隔 (如 2ms) 内 ,按照 存储 必 片 容量 的 大 小 集中 安排 奋 干 个 刷新 周 
期 ,刷新 时 停止 读 写 操作 。 

刷新 时 间 三 存储 和 矩阵 行 数 X 刷 新 周期 

这 里 刷新 周期 是 指 刷新 一 行 所 需要 的 时 间 , 巾 于 刷新 过 程 就 是 “ 假 读 ”的 过 程 , 所 以 刷新 周期 
就 等 于 存 取 周期 。 

例如 ,对 具有 1024 个 记忆 单元 (排列 成 32X 32 的 存储 矩阵 ) 的 存储 芯片 进行 刷新 ,刷新 
是 按 行进 行 的 , 且 每 刷新 一 行 占 用 一 个 存 取 周 期 ,所 以 共 需 32 个 周期 以 完成 全 部 记忆 单元 
的 刷新 。 假 设 存 取 周 期 为 500ns(0. 5ps), 则 在 2ms 内 共 可 以 安排 4000 个 存 取 周期 ,从 0 一 
3967 个 周期 内 进行 读 写 操作 或 保持 ,而 从 3968 一 3999 最 后 32 个 周期 集中 安排 刷新 操作 ， 
如 图 5-9 所 示 。 
读 写 操作 刷新 


0 ] 3967 | 3968 | 3999 
3968 个 周期 (1984hs ) 32 个 周期 (16hs) 


刷新 闻 隅 (2ms) 


5-9 集中 刷新 方式 示意 图 


集中 刷新 方式 的 优点 是 读 写 操作 时 不 受 刷 新 工作 的 影响 ,因此 系统 的 存 取 速度 比较 高 。 
主要 缺点 是 在 集中 刷新 期 间 必须 集 止 读 写 ,这 一 段 时 间 称 为 “ 死 区 ”, 而 且 存 储 容量 越 大 , 死 
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区 就 越 长 。 
(2) 分 散 刷 新 方式 
分 散 刷 新 是 指 把 刷新 操作 分 散 到 每 个 存 取 周期 内 进行 ,此 时 系统 的 存 取 周期 被 分 为 两 


= 部 分 ,前 一 部 分 时 间 进 行 读 写 操作 或 保持 ,后 一 部 分 时 间 进 行 刷新 操作 。 在 一 个 系统 存 取 周 


期 内 刷新 存储 和 矩阵 中 的 一 行 。 

这 种 刷新 方式 增加 了 系统 的 存 取 周期 , 若 存 储 芯 片 的 存 取 周 期 为 0.5ps, 则 系统 的 存 取 
周期 应 为 lws, 即 前 一 个 0. 5ps 读 写 ,后 一 个 0.5ps 刷新 。 仍 以 前 述 的 32X32 矩阵 为 例 , 整 
个 存储 芯片 刷新 一 遍 需 要 32ws, 如 图 5-10 所 示 。 


周期 0 周期 1 周期 31 


新 | 读 写 | 刷新 谈 写 | 刷新 


刷新 闻 隔 (32hs) 
图 5-10 “分 散 刷 新 方式 示意 图 


从 图 5-10 中 可 以 看 出 ,这 种 刷新 方式 没有 死 区 ,但 是 , 它 也 有 很 明显 的 缺点 : 一 是 加 长 
了 系统 的 存 取 周期 ,降低 了 整 机 的 速度 ;二 是 刷新 过 于 频繁 (本 例 中 每 32ps 就 重复 刷新 一 
这), 尤 其 是 当 存 储 容 量 比 较 小 的 情况 下 ,没有 充分 利用 所 允许 的 最 大 刷新 间隔 (2ms)。 

(3) 异步 刷新 方式 

异步 刷新 方式 可 以 看 成 前 述 两 种 方式 的 结合 , 它 充 分 利用 了 最 大 刷新 间隔 时 间 ,把 刷新 
操作 平均 分 配 到 整个 最 大 刷新 间隔 时间 内 进行 , 故 有 : 

相 邻 两 行 的 刷新 间 隅 三 最 大 刷新 间隔 时 间 一 行 数 

对 于 32X32 和 矩阵 ,在 2ms 内 需要 将 32 行 刷 新 一 过 ,所 以 相 邻 两 行 的 刷新 时 间 间 隔 二 

2ms 二 32 一 62.5ps, 即 每 隔 62. 5ps 安排 一 个 刷新 周期 。 在 刷新 时 封锁 读 写 ,如 图 5-11 所 示 。 


| 


读 写 ”1 刷新 读 写 | 刷新 读 写 ”| 刷新 
刷新 间隔 (2ms) 
图 5-11 异步 刷新 方式 示意 图 


异步 刷新 方式 虽然 也 有 和 死 区 ,但 比 集中 刷新 方式 的 死 区 小 得 多 , 仅 为 0. 5ps。 这 样 可 以 
避免 使 CPU 连续 等 待 过 长 的 时 间 ,而 且 减 少 了 刷新 次 数 , 是 比较 实用 的 一 种 刷新 方式 。 

消除 “ 死 区 ”的 方法 ,还 可 采用 不 定期 的 刷新 方式 。 其 基本 做 法 是 : 把 刷新 操作 安排 在 
CPU 不 访问 存储 器 的 空闲 时 间 里 ,如 利用 CPU 取出 指令 后 进行 译 码 的 这 段 时 间 。 这 种 方 
式 既 不 会 出 现 死 区 ,又 不 会 降低 存储 右 的 存 取 速度 ;但 是 控制 比较 复杂 ,实现 起 来 比较 困难 。 


3. 刷新 控制 


为 了 控制 刷新 ,往往 需要 增加 刷新 控制 电路 。 刷 新 控制 电路 的 主要 任务 是 解决 刷新 和 
CPU 访问 存储 带 之 间 的 了 矛盾。 通常, 当 刷 新 请 求 和 访 存 请 求 同 时 发 生 时 ,应 优先 进行 刷新 
操作 。 也 有 些 DRAM 心 厂 本 号 具有 日 动 刷新 功能 , 即 刷 新 控制 电路 在 心 片 内 部 。 

DRAM 的 刷新 要 注意 以 下 问题 : 

无 论 是 由 外 部 刷新 控制 电路 产生 刷新 地 址 逐 行 循环 地 刷新 ,还 是 芯片 内 部 的 刷新 地 
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址 计数 副 日 动 地 控制 刷新 ,都 不 依赖 于 外 部 的 访问 ,刷新 对 CPU 是 透明 的 。 

@ 刷新 通常 是 一 行 一 行 地 进行 的 ,每 一 行 中 各 记忆 单元 同时 被 刷新 , 故 刷 新 操作 时 仅 
需要 行 地 址 ,不 需要 列 地 址 。 

G) 刷新 操作 类 似 于 读 出 操作 ,但 又 有 所 不 同 。 因 为 刷新 操作 仅 是 给 栅 极 电容 补充 电 
向 ,不 需要 信息 和 输出。 另外 ,刷新 时 不 需要 加 片 选 信 号 , 即 整 个 存储 硕 中 的 所 有 芯片 同时 被 
刷新 。 

由 因为 所 有 芯片 同时 被 刷新 ,所 以 在 考虑 刷新 问题 时 ,应 当 从 单个 芯片 的 存储 容量 痢 
手 , 而 不 是 从 整个 存储 胡 的 容量 者 手 。 


S.3.3 RAM 装 片 分 析 
1 RAM 芯片 


RAM 芯片 通过 地 址 线 .数据 线 和 控制 线 与 外 部 连接 。 地 址 线 是 单 向 输入 的 ,其 数目 与 
芯片 容量 有 关 。 例 如 ,容量 为 1024X49 时 ,地 址 线 有 10 根 ; 容 量 为 64KX1 时 ,地 址 线 有 16 
根 。 数 据 线 是 双 回 的 , 既 可 输入 ,也 可 输出 ,其 数目 与 数据 位 数 有 关 。 例 如 ,1024 久 4 的 世 
片 ,数据 线 有 4 根 ;64KX1 的 芯片 ,数据 线 只 有 1 根 。 控 制 线 主 要 有 读 写 控制 线 和 片 选 线 两 
种 , 谈 写 控制 线 用 来 控制 避 片 是 进行 读 操 作 还 是 写 操 作 的 , 片 选 线 用 来 决定 该 必 片 是 否 被 选 
中 。 各 种 RAM 心 片 的 外 引 脚 主要 有 : 

。 地 址 线 一 一 A;。 

。 数据 线 一 一 Di。 

。 片 选 线 一 一 CE( 或 CS) 。 

。 读 写 控制 线 一 -WE 或 OE/ WE。 

e Vcc 一 一 十 5V ,工作 电源 。 

e GND 一 一 地 。 

有 些 SRAM 芯片 有 两 根 读 写 控制 线 : 读 允 许 线 OE 和 写 允 许 线 WE。 有些 SRAM 芯片 
只 有 1 根 读 写 控制 线 : WE, 当 WE=0 时 , 写 允 许 ;WE=1 时 , 读 人 允许 。 

由 于 DRAM 必 片 集成 度 高 ,容量 大 ,为 了 减少 必 片 引 脚 数量 ,DRAM 芯片 把 地 址 线 分 
成 相等 的 两 部 分 ,分 两 次 从 相同 的 引 脚 送 入 。 两 次 输入 的 地 址 分 别称 为 行 地 址 和 列 地 址 , 行 
地 址 由 行 地 址 选 通信 号 (Row Address Select, RAS) 送 入 存储 芯片 , 列 地 址 由 列 地 址 选 通信 
号 (Column Address Select,CAS) 送 入 存储 芯片 。 由 于 采用 了 地 址 复 用 技术 ,因此 ,DRAM 
心 片 每 增加 一 条 地 址 线 ,实际 上 是 增加 了 两 位 地 址 ,也 即 增加 了 4 售 的 容量 。 

在 DRAM 芯片 中 ,可 以 不 设 专门 的 片 选 线 CE, 而 用 行 选 通信 号 RAS、 列 选 通 CAS 兼 作 
片 选 信 号 。 


2. 地 址 译 码 方式 
RAM 世 片 中 的 地 址 译 码 电路 能 把 地 址 线 送 来 的 地 址 信号 翻译 成 对 应 存储 单元 的 选择 
信和 号。 地址 译 码 方式 有 单 译 码 和 双 诺 码 两 种 。 


@ 通常 用 Mx 六 来 描述 存储 器 或 存储 芯片 的 规格 ,其 中 M 表示 存储 单元 数 ,N 表示 每 个 单元 位 数 。 
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(1) 单 译 码 方式 

单 译 码 方式 又 称 字 选 法 ,所 对 应 的 存储 器 是 字 
结构 的 。 容 量 为 M 个 字 的 存储 器 (M 个 字 ,每 字 2 
位 ) ,排列 成 M( 行 )X2( 列 ) 的 矩阵 ,矩阵 的 每 一 行 
对 应 一 个 字 , 有 一 条 公用 的 选择 线 w;, 称 为 字 线 。 
地 址 译 码 颖 集中 在 水 平方 铝 ,K 位 地 址 线 可 译 码 变 
成 2 条 字 线 ,MM 二 2”。 字 线 选中 某 个 字 长 为 6 位 的 
存储 单元 ,经 过 2 根 位 线 可 读 出 或 写 人 2 位 存储 信 
上 息 。 在 图 5-12 所 示 结 构图 中 有 2 X8 二 256 个 记忆 
单元 ,排列 成 32 个 字 , 每 个 字 长 8 位 。 图 中 有 5 条 
地 址 线 , 经 过 译 码 产生 32 条 字 线 wo 一 wal 。 某 一 字 
线 被 选中 时 ,同一 行 中 的 各 位 bs 一 b 就 都 被 选中 ， 
由 读 写 电路 对 各 位 实施 读 出 或 写 和 操作。 

字 结 构 的 优点 是 结构 简单 ,缺点 是 使 用 的 外 
围 电路 多 ,成 本 昂贵 。 更 严重 的 是 , 当 字 数 大 大 超过 位 数 时 ,存储 体会 形成 纵 问 很 长 而 横 癌 
很 罕 的 不 合理 结构 ,所 以 这 种 方式 只 适用 于 容量 不 大 的 存储 硕 。 

(2) 双 译 人 码 方式 

双 译 码 方式 又 称 为 重合 法 。 通 常 是 把 天 位 地 址 线 分 成 接近 相等 的 两 段 , 一 段 用 于 水 平方 
向 作 X 地 址 线 , 供 X 地 址 译 码 器 译 码 ;一 段 用 于 垂直 方 品 作 Y 地 址 线 , 供 Y 地 址 译 码 器 译 码 。 
X 和 YY 两 个 方 加 的 选择 线 在 存储 体内 部 的 每 个 记忆 单元 上 交叉 ,以 选择 相应 的 记忆 单元 。 

双 译 码 方式 对 应 的 存储 芯片 结构 可 以 是 位 结构 的 ,也 可 以 是 字段 结构 的 。 对 于 位 结构 
的 存储 芯片 ,容量 为 MX1, 把 M 个 记忆 单元 排列 成 存储 矩阵 ( 尽 可 能 排列 成 方 阵 )。 
图 5-13 所 示 结 构 是 4096X1 ,排列 成 64X64 的 和 矩阵。 地址 码 共 12 位 ,X 方向 和 Y 方向 各 
6 位 ,. 若 要 组 成 一 个 M 字 Xw5 位 的 存储 器 ,就 需要 把 5 片 MX1 的 存储 芯片 并 列 连 接 起 来 ， 
即 在 图 5-13 所 示 Z 方 品 上 重合 5 个 心 片 。 


读 写 一 | 读 写 控制 电路 < 一 乒 选 


Do D, D， D， 
5-12 字 结 构 . 单 译 码 方式 RAM 


A6 AT Ag A Alo All 


5-13 位 结构 、 双 详 码 方式 RAM 
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对 于 字段 结构 的 存储 芯片 ,在 一 根 行 选择 线 上 安排 的 不 是 一 个 2 位 长 的 字 , 而 是 s 个 
b 位 长 的 字 。 这 将 使 行 选择 线 减 为 M/s 根 , 列 选择 线 数 为 ;, 而 每 一 条 列 选 线 同时 选择 5 位 数 
据 , 从 而 使 存储 芯片 的 物理 结构 大 大 改进 ,接近 或 成 为 方 阵 。 天 位 地 址 线 也 要 划分 为 两 部 
分 : K, 二 logsM/s,K, 二 logss。1KX4 的 芯片 中 共有 4096 个 记忆 单元 ,分 成 64X64 的 方 
阵 ,6 位 地 址 线 经 X 地 址 译 码 器 形成 64 根 行 选择 线 , 剩 下 的 4 位 地 址 线 经 Y 地 址 译 码 需 形 
成 16 根 列 选择 线 ,每 条 列 选择 线 同时 选择 4 位 数据 。 

典型 的 RAM 芯片 中 的 记忆 单元 总 数 往 往 开 方 之 后 仍 是 一 个 常数 ,如 1KX1,1KX4， 
2KX8,4KX1,4KX4,8KX8,16KX1,64KX1 等 ,也 就 是 使 存储 体 成 为 一 个 方 阵 。 

双 译 码 方式 与 单 译 码 方式 相 比 ,减少 了 选择 线 数目 和 驱动 器 数目 。 例 如 ,存储 容量 
N= 二 2* 二 64K 单元 ,两 种 译 码 方式 的 比较 如 表 5-2 所 示 。 存 储 容量 越 大 ,这 两 种 方式 的 差异 
越 明 显 。 


表 5-2 两 种 译 码 方式 比较 


译 码 方式 占用 地 址 位 选择 线 数 驱动 器 数 


3. RAM 的 读 写 时 序 


(1) SRAM 读 写 时 序 

图 5-14(a) 为 典型 的 读 周期 时 序 , 读 周 期 表示 对 该 芯片 进行 两 次 连续 读 操作 的 最 小 间隔 
时 间 。 在 此 期 间 , 地 址 输入 信息 不 允许 改变 , 片 选 信号 CS 在 地 址 有 效 之 后 变 为 有 效 ,使 芯 
被 选中 ,最 后 在 数据 线 上 得 到 读 出 的 信号 。 写 允许 信号 WE 在 读 周期 中 保持 高 电 平 。 


谈 周 期 写 周 期 


CS \ / CS \ / 
三 / \、_ 殉 、/ 
数据 X 数据 输出 X 数据 ”XX 数据 输入 X 


(a) (b) 
5-14 静态 RAM 的 读 写 时 序 


图 5-14(b) 为 典型 的 写 周 期 时 序 , 它 与 读 周 期 相似 ,但 除了 要 有 地 址 和 片 选 信号 外 ,还 
要 加 一 个 低 电 平 有 效 的 写 入 脉冲 WE, 并 提供 写 人 数据 。 

(2) DRAM 读 写 时 序 

DRAM 的 谈 周 期 和 写 周 期 时 序 图 分 别 如 图 5-15(a) 和 图 5-15(b) 所 示 。 

在 一 个 读 周期 中 , 行 地 址 必须 在 RAS 有 效 之 前 有 效 , 列 地 址 也 必须 在 CAS 有 效 之 前 有 
效 , 且 在 CAS 到 来 之 前 , WE 必须 为 高 电 平 ,并 保持 到 CAS 脉 冲 结束 之 后 。 

在 一 个 写 周 期 中 , 当 WE 有 效 之 后 ,输入 的 数据 必须 保持 到 CAS 变 为 低 电 平 之 后 。 在 
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写 周 其 
CAS \ / CAS \ / 
地 址 列 地 址 X  ) 地 址 列 地 址 X ) 
WE / \ WE \ / 
数据 X 数据 输出 X 数据 X 数据 输入 X 
(a) (9) 
图 5-15 动态 RAM 的 读 写 时 序 


RAS、CAS 和 WE 全 部 有 效 时 ,数据 被 写 人 存储 器 。 

5.3.4 半导体 只 读 和 存储 器 
ROM 的 最 大 优点 是 具有 非 易 失 性 ,即使 电源 断 电 ,ROM 中 存储 的 信息 也 不 会 丢失 。 
1. ROM 的 类 型 


ROM 工作 时 只 能 读 出 ,不 能 写 人 ,那么 ROM 中 的 内 容 是 如 何事 先 存 和 人 的 呢 ? 把 向 
ROM 写 入 数据 的 过 程 称 为 对 ROM 进行 编程 ,根据 编程 方法 的 不 同 ,ROM 通常 可 以 分 为 
以 下 几 类 。 

(1) 掩 膜 式 ROM(MROM) 

它 的 内 容 是 由 半导体 制造 三 按 用 户 提 出 的 要 求 在 芯片 的 生产 过 程 中 直接 写 和 人 的 , 写 人 
之 后 任何 人 都 无 法 改变 其 内 容 。 

MROM 的 优点 是 可 靠 性 高 ,集成 度 高 ,形成 批量 之 后 价格 便宜 ;缺点 是 用 户 对 制造 厂 
的 依赖 性 过 大 ,灵活 性 差 。 

(2) 一 次 可 编程 ROM(PROM) 

PROM 允许 用 户 利用 专门 的 设备 (编程 器 ) 写 和 人 自己 的 程序 ,一 旦 写 入 ,其 内 容 将 无 法 
PROM 产品 出 厂 时 ,所 有 记忆 单元 均 制 成 “0”( 或 制 成 “1”) ,用户 根据 需要 可 自行 将 其 
中 某 些 记忆 单元 改 为 “1”( 或 改 为 “0”)。 双 极 型 PROM 有 两 种 结构 ,一 种 是 燃 丝 烧 断 型 , 另 
一 种 是 PN 结 击 穿 型 ,由 于 它们 的 写 入 都 是 不 可 逆 的 ,所 以 只 能 进行 一 次 性 写 信 。 

(3) 可 擦 除 可 编程 ROM(EPROM) 

EPROM 不 仅 可 以 由 用 户 利用 编程 器 写 人 信息 ,而 且 可 以 对 其 内 容 进 行 多 次 改写 。 

EPROM 出 厂 时 ,存储 内 容 为 全 “1”, 用户 可 以 根据 需要 将 其 中 某 些 记 忆 单 元 改 为 “0”。 
当 需 要 更 新 存储 内 容 时 可 以 将 原 存 储 内 容 擦 除 ( 恢 复 全 “1”) ,以 便 再 写 人 新 的 内 容 。 

EPROM 又 可 分 为 两 种 : 紫外 线 擦 除 (UVEPROM) 和 电 擦 除 (EEPROM)。 

UVEPROM 需 用 紫外 线 灯 制作 的 擦 抹 右 照射 存储 器 心 片 上 的 透明 窗口 ,使 芯片 中 原 存 
内 容 被 擦 除 。 由 于 是 用 紫外 线 灯 进行 擦 除 ,所 以 只 能 对 整个 芯片 擦 除 , 而 不 能 对 芯片 中 个 别 
需要 改写 的 存储 单元 单独 擦 除 。 男 外 ,为 了 防止 存储 的 信息 受 日 光 中 紫外 线 成 分 的 作用 而 
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缓慢 丢失 ,在 UVEPROM 芯片 写 和 人 完成 后 ,必须 用 不 透明 的 黑 纸 将 芯片 上 的 透明 窗口 
封 住 。 

EEPROM 是 采用 电气 方法 来 进行 擦 除 的 ,在 联机 条 件 下 既 可 以 用 字 擦 除 方 式 擦 除 , 也 
可 以 用 数据 块 擦 除 方式 擦 除 。 以 字 擦 除 方式 操作 时 ,能 够 只 擦 除 被 选中 的 那个 存储 单元 的 
内 容 ;在 数据 块 擦 除 方式 操作 时 ,可 擦 除数 据 块 内 所 有 单元 的 内 容 。 

EPROM 虽然 既 可 读 , 又 可 写 ,但 它 却 不 能 取代 RAM。 原 因 如 下 : 

(EPROM 的 编程 次 数 ( 寿 命 ) 是 有 限 的 。 

凶 写 人 时 间 过 长 ,即使 对 于 EEPROM , 探 除 一 个 字 节 大 约 需要 10ms, 写 入 一 个 字 节 大 
约 需要 10ws, 比 SRAM 或 DRAM 的 时 间 长 100 一 1000 倍 。 

(4) 闪 速 存储 需 

内 速 存储 器 (Flash Memory, 人 简称 闪存 ) 是 一 种 允许 在 操作 中 被 多 次 擦 除 或 重 写 的 只 读 
存储 器 , 它 的 主要 特点 是 既 可 在 不 加 电 的 情况 下 长 期 保存 信息 ,又 能 在 线 进行 快速 擦 除 与 重 
写 ,兼备 了 EEPROM 和 RAM 的 优点 。 

闪 速 存储 器 有 NOR 型 和 NAND 型 两 种 。NOR Flash 需要 很 长 的 时 间 进 行 擦 写 , 人 允许 
随机 存 取 存储 硕 上 的 任何 区 域 , 读 取 数 据 的 方式 与 从 RAM 读 取 数据 很 相近 ,这 使 得 它 非常 
适合 取代 老式 的 ROM 芯片 。NAND Flash 具有 较 快 的 擦 写 时 间 , 但 必须 以 区 块 为 单位 进 
行 读 取 。 

目前 ,大 多 数 微 型 计算 机 的 主板 采用 闪 速 存储 需 来 存储 BIOS 程序 。 由 于 BIOS 的 数据 
和 程序 非常 重要 ,不 允许 修改 , 故 早期 主板 BIOS 芯片 多 采用 PROM 或 EPROM。 闪 速 存储 
器 除了 具有 ROM 的 一 般 特 性 外 ,还 有 低 电压 改写 的 特点 ,便于 用 户 自 动 升级 BIOS。 


2，ROM 芯片 


ROM 中 使 用 最 多 的 是 可 擦 除 可 编程 ROM(EPROM)。 各 种 EPROM 芯片 的 外 引 脚 主 
要 有 : 

。 地址 线 : A; 。 

e。 数据 线 : Di。 

。 片 选 线 : CS( 或 CE) 。 

。 编程 线 : PGM。 

e。 电源 线 : Vec 一 一 十 5V, 工 作 电 源 ; Vep 一 一 编程 电源 ; GND 一 一 地 。Vpp 平 时 接 

十 5V ,编程 写 人 时 , 需 接 高 于 Vcc 右 干 倍 的 编程 电压 。 


5.3.5 半导体 存储 器 的 封装 
1. DIP 存储 芯片 


过 去 ,一般 存 储 心 片 都 是 双 列 直 插 封装 (Dual In-line Package,DIP) 的 。 这 种 内 存世 片 
必须 焊接 在 主板 上 才能 使 用 ,一 旦 某 一 块 蕊 片 坏 了 ,必须 焊 下 来 才能 更 换 ，。 

DIP 芯片 的 容量 一 般 不 可 能 很 大 ,如 64KX1l1 或 256KX1 的 芯片 ,表示 每 个 芯片 具有 
64K 或 256K 个 记忆 单元 , 耕 要 存储 256KB 的 信息 , 则 需要 8 个 256KX1 的 芯片 ( 非 奇 偶 校 
验 ) 或 9 个 这 样 的 世上 请 ( 奇 偶 校 验 ) 。 
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2. 内 存 条 


目前 ,厂家 广泛 地 使 用 单列 直 插 存储 模块 (Single In-line Memory Module,SIMM)、 双 
列 直 插 存储 模块 (Dual In-line Memory Module, DIMM) 以 及 Rambus 直 插 存储 模块 
(Rambus In-line Memory Module, RIMM) ,这 些 就 是 通常 所 说 的 内 存 条 。 内 存 条 实际 上 是 
一 条 焊 有 多 片 存储 心 片 的 印刷 电路 板 , 插 在 主板 内 存 插 槽 中 (不 同 的 内 存 条 必须 安装 在 与 其 
对 应 的 专用 插 模 上 ) ,这 样 内 存 条 就 可 以 随意 拆卸 了 。 

SIMM 有 30 线 和 72 线 两 种 。30 线 的 SIMM 诞生 于 286 时 代 , 数 据 线 的 宽度 只 有 8 位 
(部 分 另 加 有 1 位 校 验 位 ) ,需要 用 4 条 SIMM 组 成 一 组 来 构成 具有 某 种 容量 和 32 位 数据 
宽度 的 主 存储 副 。72 线 的 SIMM ,数据 线 的 宽度 有 32 位 ( 非 奇 偶 校 验 ) 或 36 位 (奇偶 校 
验 ) ,每 一 条 就 可 以 构成 具有 某 种 容量 和 32 位 数据 宽度 的 主 存储 需 。 

DIMM 有 多 种 类 型 :标准 的 DIMM、DDR DIMM、DDR2 DIMM、DDR3 DIMM 和 
DDR4 DIMM。 标 准 的 DIMM 每 面 84 线 , 双 面 共 有 84 线 X2= 二 168 线 , 故 而 和 常 称 为 168 线 
内 存 条 。 而 DDR 每 面 92 线 , 双 面 共 有 184 线 。DDR2 和 DDR3 每 面 都 是 120 线 , 双 面 共 有 
240 线 ,但 缺口 的 位 置 有 所 不 同 。DDR4 的 双 面 共有 284 线 。 所 有 DIMM 的 数据 线 宽 度 都 
是 64 位 ( 非 奇 偶 校 验 ) 或 72 位 (奇偶 校 验 ) ,所 以 在 现代 PC 中 ,只 需 一 条 DIMM 就 可 构成 具 
有 某 种 容量 和 64 位 数据 宽度 的 主 存储 需 。 

为 了 满足 便携 式 计 算 机 对 内 存 尺 寸 的 要 求 , SO-DIMM (Small Outline Dual In-line 
Memory Module) 应 运 而 生 。SO-DIMM 中 文 含意 为 “小 外 形 双 列 直 插 存储 模块 ”, 它 的 外 形 
尺寸 大 致 是 正常 DIMM 尺寸 的 一 半 。SO-DIMM 具有 72 线 (支持 32 位 数据 传输 ) 以 及 144 
线 、200 线 和 260 线 ( 支 持 64 位 数据 传输 ) 等 。 

RIMM 也 是 双 面 的 ,目前 只 有 一 种 RIMM, 它 有 184 线 。 一 个 通道 通常 有 3 个 RIMM 
插 槽 ,所 有 RIMM 插 槽 必须 全 部 插 满 ,如 有 空余 则 要 用 专用 的 Rambus 终结 器 填 满 。 

大 多 数 主 板 不 允许 用 户 把 不 同 容 量 的 内 存 条 混用 ,用 户 应 在 满足 主 存 容量 的 同时 ,使 内 
存 条 的 数目 尽 可 能 少 , 这 将 为 进一步 扩充 主 存 容 量 留 下 余地 。 


5.4 主 存储 怖 的 连接 与 控制 
由 于 存储 芯片 的 容量 是 有 限 的 , 主 存 储 器 往往 是 要 由 一 定数 量 的 芯片 构成 的 。 而 由 若 
干 芯片 构成 的 主 存 还 需要 与 CPU 连接 ,才能 在 CPU 的 正确 控制 下 完成 读 写 操作 。 
S.4.1 主 存 容量 的 扩展 


要 组 成 一 个 主 存 , 首 先 要 考虑 选 片 的 问题 ,然后 就 是 如 何 把 世族 连接 起 来 的 问题 。 根 据 
存储 带 所 要 求 的 容量 和 选 定 的 存储 必 片 的 容量 ,就 可 以 计算 出 总 的 芯片 数 , 即 


兴安 是 
总 片 数 一 -和 宝 全 


容量 / 片 
例如 ,存储 器 容量 为 8KX8, 知 选用 1KX4 的 存储 沪 片 , 则 需要 . 
SX8 一 8X2 片 二 16 片 


lKx4 


个 迄 系统 和 结 欧 


将 多 片 组合 起 来 第 采用 位 扩展 法 、 字 扩展 法 、 字 和 位 同时 扩展 法 。 
1. 位 扩展 


位 扩展 是 指 只 在 位 数 方向 扩展 (加 大 字 长 ) ,而 芯片 的 字数 和 存储 需 的 字数 是 一 致 的 。 
位 扩展 的 连接 方式 是 将 各 存储 芯片 的 地 址 线 . 片 选 线 和 读 写 线 相 应 地 并 联 起 来 ,而 将 各 必 片 


的 数据 线 单独 列 出 。 
如 用 64KX1 的 SRAM 必 片 组 成 64KX8 的 存储 右 , 所 需 心 片 数 为 
64KX8 
64 民 又 1 一 请 


在 这 种 情况 下 ,CPU 将 提供 16 根 地 址 线 (2* 二 65 536)、8 根 数据 线 与 存储 器 相连 ;而 存 
储 芯片 仅 有 16 根 地 址 线 、1 根 数据 线 。 具 体 的 连接 方法 是 : 8 个 芯片 的 地 址 线 As 一 An 
分 别 连 在 一 起 ,各 芯片 的 片 选 信号 CS 以 及 读 写 控制 信号 WE 也 都 分 别 连 到 一 起 ,只 有 数据 线 
D; 一 Do 各 自 独 立 , 每 片 代表 一 位 ,如 图 5-16 所 示 。 
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5-16 位 扩展 连接 举例 


当 CPU 访问 该 存储 器 时 ,其 发 出 的 地 址 和 控制 信号 同时 传 给 8 个 芯片 ,选中 每 个 芯片 
的 同一 单元 ,相应 单元 的 内 容 被 同时 读 至 数据 总 线 的 各 位 ,或 将 数据 总 线 上 的 内 容 分 别 同时 
写 人 相应 单元 。 


2. 字 扩 展 


字 扩 展 是 指 仅 在 字数 方向 扩展 ,而 位 数 不 变 。 字 扩展 将 芯片 的 地 址 线 .数据 线 、. 读 写 线 
并 联 , 由 片 选 信号 来 区 分 各 个 芯片 。 
如 用 16KX8 的 SRAM 组 成 64K X38 的 存储 器 ,所 需 芯 片 数 为 : 


64KX8 
16 民 又 8 一 全 片 


在 这 种 情况 下 ,CPU 将 提供 16 根 地 址 线 、8 根 数据 线 与 存储 器 相连 ;而 存储 芯片 仅 有 
14 根 地 址 线 、8 根 数据 线 。4 个 芯片 的 地 址 线 As 一 Au .数据 线 D; 一 D, 及 读 写 控制 信号 WE 
都 是 同名 信号 并 联 在 一 起 ;CPU 的 高 位 地 址 线 Als、Au 经 过 一 个 地 址 译 码 器 产生 4 个 片 选 
信号 CS; ,分 别 选 中 4 个 芯片 中 的 一 个 ,如 图 5-17 所 示 。 

Ais Au 二 00, 选 中 第 一 片 ; Ais Au 二 01, 选 中 第 二 片 …… 

在 同一 时 间 内 4 个 芯片 中 只 能 有 一 个 芯片 被 选中 。4 个 芯片 的 地 址 分 配 如 下 : 
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图 5-17 字 扩 展 连 接 举 例 


第 一 片 最 低地 址 ”0000 0000 0000 0000B 0000H 
最 高 地 址 0011 1111 1111 1111B 3FFFH 
第 二 片 ”最 低地 址 ”0100 0000 0000 0000B 4000H 
最 高 地 址 0111 1111 1111 1111B 7FFFH 
第 三 片 ” 最低 地址 1000 0000 0000 0000B 8000H 
最 高 地 址 。 1011 1111 1111 1111B BFFFH 
第 四 上 最 低地 址 1100 0000 0000 0000B C000H 
最 高 地 址 1111 1111 1111 1111B FFFFH 


3. 字 和 位 同时 扩展 


当 构 成 一 个 容量 较 大 的 存储 器 时 ,往往 需要 在 字数 方向 和 位 数 方 品 上 同时 扩展 ,这 将 是 
前 两 种 扩展 的 组 合 ,实现 起 来 也 是 很 容易 的 。 
图 5-18 表示 用 8 片 16KX4 的 SRAM 芯片 组 成 64KX8 存储 器 的 连接 图 。 
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图 5-18 字 和 位 同时 扩展 连接 举例 


疗 储 系 统 和 结构 


不 同 的 扩展 方法 可 以 得 到 不 同 容 量 的 存储 带 。 在 选择 存储 发 片 时 ,一 般 应 尽 可 能 使 用 
集成 度 高 的 存储 芯片 来 满足 总 的 存储 容量 的 要 求 , 这 样 可 减少 成 本 ,还 可 减轻 系统 负载 , 缩 
小 存储 天 模块 的 矿 才 。 


5.4.2 存储 芯片 的 地 址 分 配 和 片 选 


CPU 与 存储 天 连接 时 ,特别 是 在 扩展 存储 容量 的 场合 下 , 主 存 的 地 址 分 配 是 一 个 重要 
的 问题 。 确 定 地 址 分 配 后 ,又 有 一 个 存储 芯片 的 片 选 信号 的 产生 问题 。 

CPU 要 实现 对 存储 单元 的 访问 ,首先 要 选择 存储 必 片 , 即 进行 请 选 :然后 再 从 选中 的 世 
片 中 依 地 址 码 选择 出 相应 的 存储 单元 ,以 进行 数据 的 存 取 , 这 称 为 字 选 。 片 内 的 字 选 是 由 
CPU 送出 的 N 条 低位 地 址 线 完成 的 ,地 址 线 直 接 接 到 所 有 存储 发 片 的 地 址 输入 端 (N 由 片 
内 存储 容量 2 决定 ) 。 而 存储 忆 片 的 片 选 信号 则 大 多 是 通过 高 位 地 址 详 码 或 直接 连接 产 
生 的 。 

片 选 信号 的 产生 可 细 分 为 线 选 法 、 全 译 人 码 法 和 部 分 译 码 法 。 


1. 线 选 法 


线 选 法 就 是 用 除 片 内 寻 址 外 的 高 位 地 址 线 直 接 ( 或 经 反 相 器 ) 分 别 接 至 各 个 存储 发 片 的 
片 选 端 , 当 某 地 址 线 信息 为 “0” 时 ,就 选中 与 之 对 应 的 存储 芯片 。 
注意 : 这 些 片 选 地 址 线 每 次 寻 址 时 只 能 有 一 位 有 效 , 不 允许 同时 有 多 位 有 效 , 这 样 才能 
保证 每 次 只 选中 一 个 芯片 (或 组 )。 
假设 4 片 2KX8 用 线 选 法 构成 8KX8 存储 器 ,各 忌 片 的 地 址 分 配 如 表 5-3 所 示 。 
表 5-3” 线 选 法 的 地 址 分 配 


O00*.*…:0 

0 间 1110 : 7000~~77FFH 
11*.…1 
00*.…:0 

1## 1101 : 6800 一 6FFFH 
11**…1 
O00***0 

2# 1011 : 5800~5FFFH 
11*.…1 
O00*.…:0 

3# 0111 : 3800~3FFFH 
11*.…1 


线 选 法 的 优点 是 不 需要 地 址 诺 码 豆 ,线路 简单 ,选择 忌 卢 无须 外 加 逻辑 电路 ,但 仅 适 用 
于 连接 存储 心 片 较 少 的 场合 。 同 时 , 线 选 法 不 能 充分 利用 系统 的 存储 融 空 间 , 且 把 地 址 空间 
分 成 相互 隔离 的 区 域 , 给 编程 带 来 了 一 定 的 困难 。 


2. 全 译 码 法 
全 详 码 法 将 除 片 内 寻 址 外 的 全 部 高 位 地 址 线 都 作为 地 址 译 码 需 的 输入 , 译 码 需 的 输出 
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作为 各 芯片 的 片 选 信号 ,将 它们 分 别 接 到 存储 芯片 的 片 选 端 ,以 实现 对 存储 芯片 的 选择 。 

全 详 码 法 的 优点 是 每 片 (或 组 ) 必 片 的 地 址 范围 是 唯一 确定 的 ,而 且 是 连续 的 ,也 便于 扩 
展 , 不 会 产生 地 址 重 释 的 存储 区 ,但 全 译 码 法 对 译 码 电路 要 求 较 高 。 

例如 ,CPU 的 地 址 总 线 有 20 位 , 现 用 4 片 2KX8 的 存储 芯片 组 成 一 个 8K X38 的 存储 
顷 。 全 译 人 码 法 要 求 除去 片 内 寻 址 用 到 的 11 位 地 址 线 外 ,高 9 位 地 址 As 一 An 都 要 参与 详 
码 。 各 心 片 的 地 址 分 配 如 表 5-4 所 示 。 


表 5-4 全 译 码 法 的 地 址 分 配 


3# jw | : 01800 一 01FFFHH 
1]11...1] 


3. 部 分 译 码 法 


所 谓 部 分 译 码 就 是 用 除 片 内 寻 址 外 的 高 位 地 址 的 一 部 分 来 译 码 产生 片 选 信 号 。 如 用 4 
片 2KX8 的 存储 芯片 组 成 8KX8 存储 器 ,需要 4 个 片 选 信号 ,因此 只 需要 用 两 位 地 址 线 来 
译 码 产生 。 

由 于 寻 址 8K X 8 存储 硕 时 未 用 到 高 位 地 址 8Kx8 存 储 器 IMX8 存 储 空间 
Ay 一 Ays, 所 以 无 论 Ay ~ Ais 取 何 值 ,只 要 A = 
An 二 0, 则 选中 第 一 片 ; 只 要 Al =0,Alu 王 1, 则 
选中 第 二 片 ;…… 也 就 是 说 ,8K RAM 中 的 任 一 
个 存储 单元 ,都 对 应 有 2 31? 王 27 个 地 址 ,这 种 
一 个 存储 单元 出 现 多 个 地 址 的 现象 称 地 址 重 释 。 

从 地 址 分 布 来 看 ,这 8KB 存储 器 实际 上 占 
用 了 CPU 全 部 的 空间 (1MB)。 每 片 2KX8 的 存 


储 芯片 有 二 M 一 256K 的 地 址 重 释 区 ,如 图 5-19 
所 示 。 

令 未 用 到 的 高 位 地 址 全 为 0, 这 样 确 定 的 存 
储 器 地 址 称 为 基本 地 址 ,本 例 中 8KX8 存储 器 的 基本 地 址 即 00000H 一 01FFFH。 部 分 译 码 
法 较 全 译 人 码 法 人 简单 ,但 存在 地 址 重生 区 ， 


图 5-19 地址 重 委 区 示意 图 


疗 储 系统 和 结 榴 


5.4.3 主 存储 器 和 CPU 的 连接 
在 讨论 了 主 存 的 结构 之 后 ,进一步 了 解 主 存 和 CPU 之 间 的 连接 是 十 分 必要 的 。 
1. 主 存 和 CPU 之 间 的 硬 连接 
主 存 与 CPU 的 硬 连 接 有 3 组 连 线 : 地 址 总 线 (AB) .数据 总 线 C(DB) 和 控制 总 线 C(CB)， 


如 图 5-20 所 示 。 此 时 ,把 主 存 看 作 一 个 黑 盒 子 , 存 网 
储 器 地 址 寄存 器 (MAR) 和 存储 器 数据 寄存 器 一 
CMDR) 是 主 存 和 CPU 之 间 的 接口 。MAR 可 以 接 | cp 人 、 0 
受 来 自 程序 计数 器 (PC) 的 指令 地 址 或 来 自 地 址 形 
成 部 件 的 操作 数 地 址 ,以 确定 要 访问 的 单元 。MDR 


是 回 主 存 写 人 数据 或 从 主 存 谈 出 数据 的 缓冲 部 件 。 
MAR 和 MDR 从 功能 上 看 属于 主 存 ,但 在 小 型 计算 
机 、 微 型 计算 机 中 常 放 在 CPU 内 。 


2. CPU 对 主 存 的 基本 操作 


前 面 所 说 的 CPU 与 主 存 的 便 连 接 是 两 个 部 件 之 间 联 系 的 物理 基础 。 而 两 个 部 件 之 间 
还 有 软 连接 , 即 CPU 向 主 存 发 出 的 读 或 写 命令 ,这 才 是 两 个 部 件 之 间 有 效 工 作 的 关键 。 

CPU 对 主 存 进行 读 写 操作 时 ,首先 CPU 在 地 址 总 线 上 给 出 地 址 信号 ,然后 发 出 相应 的 
读 或 写 命令 ,并 在 数据 总 线 上 交换 信息 。 读 写 的 基本 操作 如 下 。 

(1) 读 

读 操 作 是 指 从 CPU 送 来 的 地 址 所 指定 的 存储 单元 中 取出 信息 ,再 送 给 CPU ,其 操作 过 
程 是 : 


5-20” 主 存 和 CPU 的 硬 连接 


中 地址 MAR 卫 AB CPU 将 地 址 信号 送 至 地 址 总 线 。 

© Read CPU 发 读 命令 。 

G@) Wait for MFC 等 竺 存储 器 工作 完成 信号 。 

由 M(MAR) 一 DB 一 MDR  ” 读 出 信息 经 数据 总 线 送 至 CPU 。 

(2) 写 

写 操 作 是 指 将 要 写 人 的 信息 存 和 人 CPU 所 指定 的 存储 单元 中 ,其 操作 过 程 是 : 
中 地 址 MAR 一 AB CPU 将 地 址 信号 送 至 地 址 总 线 。 

@ 数据 一 MDR 一 DB CPU 将 要 写 入 的 数据 送 至 数据 总 线 。 

@ Write CPU 发 写 命令 。 

@ Wait for MFC 等 待 存储 器 工作 完成 信号 。 


由 于 CPU 和 主 存 的 速度 存在 着 差距 ,所 以 两 者 之 间 的 速度 匹配 是 很 关键 的 。 通 常 有 
两 种 匹配 方式 : 同步 存储 器 读 取 和 异步 存储 右 读 取 。 上 面 给 出 的 读 写 基本 操作 是 以 异步 存 
储 希 读 取 来 考虑 的 ,CPU 和 主 存 之 间 没 有 统一 的 时 钟 ,由 主 存 工作 完成 信号 (MFC) 通 知 
CPU“ 主 存 工 作 已 完成 >。 对 于 读 操 作 , 若 MFC=1, 说 明 信 息 已 经 读 出 ;对 于 写 操作 , 若 
MFC 王 1, 说 明 数据 已 写 人 相应 的 存储 单元 。 

对 于 同步 存储 器 读 取 ,CPU 和 主 存 采用 统一 时 钟 ,同步 工作 ,因为 主 存 速 度 较 慢 ,所 以 
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CPU 与 之 配合 必须 放 慢 速 度 。 在 这 种 存储 器 中 ,不 需要 主 存 工 作 完 成 信号 。 
5.4.4 主 存 的 校 验 


计算 机 在 运行 过 程 中 , 主 存 要 与 CPU 频 绽 地 交换 数据 。 为 了 检测 和 校正 在 存储 过 程 
中 的 错误 , 主 存 中 常设 置 有 差错 校 验 电路 。 


1. 主 存 的 奇偶 校 验 


最 简单 的 主 存 检验 方法 是 奇偶 校 验 , 有 关 奇 偶 校 验 的 概念 已 经 在 第 2 章 进 行 了 讨论 。 
在 微机 中 通常 采用 奇 校 验 , 即 每 个 存储 单元 中 共存 储 9 位 信息 (其 中 8 位 数据 ,1 位 奇偶 校 
验 位 ) ,信息 中 “1” 的 个 数 总 是 奇数 。 

当 向 主 存 写 人 数据 时 ,奇偶 校 验 电路 首先 会 对 一 个 字 节 的 数据 计算 出 奇偶 校 验 位 的 值 ， 
然后 再 把 所 有 的 9 位 值 一 起 送 到 主 存 中 。 

读 出 数据 时 , 某 一 存储 单元 的 9 位 数据 被 同时 读 出 , 当 9 位 数据 里 *1” 的 个 数 为 奇数 时 ， 
表示 读 出 的 9 位 数据 正确 (当然 不 排除 有 2 位 同时 出 错 的 可 能 ,但 其 概率 极 小 ); 当 “1” 的 个 
数 为 偶数 时 ,表示 读 出 数据 出 错 ,向 CPU 发 出 不 可 屏蔽 中 断 , 使 系统 停机 并 显示 奇偶 检验 
出 错 的 信息 。 


2. 错误 检验 与 校正 (ECC) 


虽然 奇偶 校 验 主 存 仍 在 使 用 ,但 它 的 继承 者 “错误 校 验 与 校正 (Error Checking and 
Correcting,ECC) ”已 经 广泛 取代 了 它 ,ECC 不 仅 能 检测 错误 还 能 在 不 打扰 计算 机 工作 的 情 
况 下 改正 错误 ,这 对 于 网 络 服务 器 这 样 不 允许 随便 停机 的 关键 任务 是 至 关 重 要 的 。 最 常用 
的 ECC 就 是 第 2 章 中 提 到 的 汉 明 码 校 验 , 可 对 已 访问 的 数据 字段 进行 单位 错误 的 检测 和 修 
复 , 而 对 双 位 错误 只 能 检测 不 能 修复 。 

ECC 主 存 用 一 组 附加 数据 位 来 存储 一 个 特殊 码 ,被 称 为 “ 校 验 和 ”。 对 于 每 个 二 进 制 字 
都 有 相应 的 ECC 码 。 产 生 ECC 码 所 需 的 位 数 取 决 于 系统 所 用 的 二 进 制 字 长 。 例 如 ,32 位 
字 要 求 有 7 位 ECC 码 , 此 时 ECC 的 开销 大 于 奇偶 校 验 的 开销 ;64 位 字 要 求 有 8 位 ECC 码 ， 
此 时 ECC 和 奇偶 校 验 的 开销 是 一 样 的 。 

ECC 在 存储 器 写 操 作 时 需要 存储 器 控制 器 计算 校 验 位 , 当 从 主 存 中 读 取 数据 时 ,将 取 
到 的 实际 数据 和 它 的 ECC 码 快速 比较 。 如 果 匹 配 , 则 实际 数据 被 传 给 CPU; 如 果 不 匹配 ， 
则 ECC 码 的 结构 能 够 将 出 错 的 一 位 鉴别 出 来 ,然后 改正 错误 ,再 将 数据 传 给 CPU 。 

注意 : 此 时 主 存 中 的 出 错位 并 没有 改变 ,如 果 又 要 读 取 这 个 数据 ,需要 再 一 次 校正 
错误 。 
大 多 数 存 储 器 的 错误 具有 单位 出 错 的 特征 ,能 够 被 ECC 纠正 过 来 ,这 种 容错 技术 提高 
了 系统 的 可 靠 性 和 可 用 性 。 基 于 ECC 的 系统 是 服务 器 、 工 作 站 和 重要 应 用 的 最 佳 选择 。 

现代 的 PC 中 主 存 的 容错 能 力 被 分 为 基本 的 三 级 : 

QD 无 奇偶 检验 。 

@O) 奇偶 检验 。 

@ ECC。 

无 奇偶 校 验 的 主 存根 本 就 没有 容错 能 力 。 它 们 之 所 以 被 使 用 ,仅仅 是 因为 其 价格 最 低 ， 
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且 无 奇偶 校 验 主 存 的 控制 部 件 相 对 简单 。 
5.4.5 PC 系列 微型 计算 机 的 存储 器 接口 


8088 .8086 .80386 和 Pentium 微 处 理 硕 的 外 部 数据 总 线 分 别 是 8 位 16 位 32 位 和 64 
位 ,下 面 介 绍 它 们 与 主 存 的 接口 。 


1. 8 位 存储 器 接口 


如 果 数 据 总 线 为 8 位 (如 微机 系统 中 的 PC 总 线 ) ,而 主 存 按 字 节 编 址 , 则 匹配 关系 比较 
简单 。 对 于 8 位 的 微 处 理 右 ,典型 的 时 序 安排 是 占用 4 个 CPU 时 钟 周 期 , 称 为 Ti 一 T, 构 
成 一 个 总 线 周 期 。 对 于 微型 计算 机 来 说 ,存储 颖 就 接 在 总 线 上 , 故 总 线 周期 就 等 于 存 取 周 
期 ,一 个 总 线 周 期 可 读 写 8 位 。 

8 位 的 微 处 理 器 8088 提供 RD( 读 选 通 ) 、WR( 写 选 通 ) 和 IO/M(I/O 或 存储 器 控制 ) 等 
控制 信号 (最 小 模式 ) 去 控制 存储 器 系统 ,或 者 提供 IO/M 与 RD 一 起 产生 的 MRDC( 存 储 器 
读 命 令 ) .I0/M 与 WR 一 起 产生 的 MWTC( 存 储 器 写 命令 ) 等 控制 信号 (最 大 模式 ) 去 控制 存 


2. 16 位 存储 器 接口 


对 于 16 位 的 微 处 理 器 8086( 或 80286) ,在 一 个 总 线 周 期 内 最 多 可 读 写 两 个 字 节 , 即 从 
偶 地 址 开始 的 字 ( 规 则 字 )。 同 时 , 读 写 这 个 偶 地 址 单元 和 随后 的 奇 地 址 单元 ,用 低 8 位 数据 
总 线 传 送 偶 地 址 单元 的 数据 ,用 高 8 位 数据 总 线 传送 奇 地 址 单元 的 数据 。 如 果 读 写 的 是 非 
规则 字 , 即 是 从 奇 地 址 开始 的 字 , 则 需要 安排 两 个 存 取 周 期 才能 实现 。 

为 了 实现 这 样 的 传送 ,需要 将 存储 器 分 为 两 个 存储 体 ,如 图 5-21 所 示 。 一 个 存储 体 的 
地 址 均 为 偶数 , 称 为 偶 地 址 ( 低 字 节 ) 存 储 体 , 它 与 低 8 位 数据 总 线 相连 ; 男 一 个 存储 体 的 地 
址 均 为 奇数 , 称 为 奇 地 址 (高 字 节 ) 存 储 体 ,与 高 8 位 数据 总 线 相连 。 


可 存储 体 偶 和 存储 体 
512KB 512KB 


Dis~Dse _ D>~D 
Alo~Al 15 BHE 7 0 Al 


图 5-21 8086 的 存储 器 组 织 


8086 微 处 理 器 的 地 址 线 As 一 A; 同时 送 至 两 个 存储 体 ,BHE( 高 位 存储 体 ) 和 最 低位 地 
址 线 A。 用 来 选择 一 个 或 两 个 存储 体 进 行 数据 传送 。BHE 和 A 的 选择 如 表 5-5 所 示 。 
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表 5-5 BHE 和 A 的 选择 表 


0 0 全 字 ( 规 则 字 ) 传 送 

0 1 在 数据 总 线 高 8 位 上 进行 字 节 传送 
1 0 在 数据 总 线 低 8 位 上 进行 字 节 传送 
1 1 备用 


8086 和 主 存 之 间 可 以 传送 一 个 字 节 (8 位) 数据 ,也 可 以 传送 一 个 字 (16 位 ) 数 据 。 任 何 
两 个 连续 的 字 节 都 可 以 作为 一 个 字 来 访问 ,地 址 值 较 低 的 字 节 是 低位 有 效 字 节 , 地 址 值 较 高 
的 字 节 是 高 位 有 效 字 节 。 

图 5-22 给 出 了 各 种 信息 的 传送 方法 : 图 5-22(a) 为 偶 地 址 字 节 传送 ,图 5-22(b) 为 奇 地 
址 字 节 传送 ;图 5-22(c) 为 偶 地 址 字 传 送 , 图 5-22(d) 和 图 5-22(e) 为 奇 地 址 字 传 送 。 从 图 中 
可 以 看 出 ,对 于 规则 字 ( 边 界 对 齐 的 偶 地 址 字 ) 进 行 读 写 , 仅 需 一 个 存 取 周期 ;而 对 于 非 规 则 
字 ( 边 界 未 对 齐 的 奇 地 址 字 ) 进 行 读 写 ,就 需要 两 个 存 取 周 期 ,而 且 每 次 都 应 忽略 掉 不 需要 的 
半 个 字 。 


D's 


DDo AH) 


Ds BHEH) TY AD) Aiy~A! Ys BHEL) 
(b) 


D 1s~Ds 


i Dl == D-~D 
BHE(L) DrDo AH) Alg~Al ls “8 BHE(H) 7 0 Ao(L) 
(d) (e) 


图 5-22 各 种 信息 的 传送 方法 
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3. 32 位 存储 器 接口 


由 于 80386/80486 微 处 理 器 要 保持 与 8086 等 微 处 理 器 兼容 ,这 就 要 求 在 进行 存储 器 系 
统 设 计时 必须 满足 单字 节 、 双 字 节 和 四 字 节 等 不 同 访问 。 为 了 实现 8 位 、16 位 和 32 位 数据 
的 访问 ,80386/80486 微 处 理 器 设 有 4 个 引 脚 BE; 一 BE ,以 控制 不 同 数据 的 访问 。BE: 一 
BE。 由 CPU 根据 指令 的 类 型 产生 ,其 作用 如 表 5-6 所 示 。 
表 5-6 BE, ~ 一 BE, 功能 表 
要 访问 的 数据 位 


GODrnrnrr 


~D, 
D; ~ D, 


名 


OO OO OO ~ OO OO ~ ~ OO 
OO ~ OO OO ~ 一 
”A 


1 
1 
0 
1 
1 
0 
0 
0 
0 
0 


OO OO ~ OO 一 OO ~ 一 


从 表 5-6 中 可 以 看 出 ,在 8 位 和 16 位 数据 传送 中 , 当 微 处 理 颖 写 入 高 字 节 或 高 16 位 数 
据 时 ,该 数据 将 在 低 字 节 或 低 16 位 数据 线 上 重复 输出 。 其 目的 是 为 了 加 快 数据 传送 的 速 
度 , 但 是 是 否 能 够 写 入 低 字 节 或 低 16 位 单元 , 则 由 相应 的 BE, 决定 。 

32 位 微 处 理 器 的 存储 器 组 织 如 图 5-23 所 示 。80386/80486 微 处 理 器 有 32 位 地 址 线 ， 
但 是 直接 输入 As 一 A: , 低 两 位 A; 一 Au 由 内 部 编码 产生 BE: 一 BE ,以 选择 不 同 字 节 。 主 存 
由 4 个 存储 体 组 成 ,每 个 存储 体 的 存储 空间 可 达 1GB。 如 果 要 访问 一 个 32 位 数 ,那么 4 个 
存储 体 都 被 选中 ; 若 要 访问 一 个 16 位 数 , 则 有 两 个 存储 体 ( 通 常 是 BE: 和 BE 或 者 BE， 和 
BE。 ) 被 选中 ; 若 访问 的 是 8 位 数 , 只 有 一 个 存储 体 被 选中 。 


BE, 
00000003 昌 00000002H 00000001H 00000000H 
仓储 体 Em i 存储 体 
0 
FFFFFFFFH FFFFFFFEH FFFFFFFDH FFFFFFFCH 
D31~D24 D»3~D1e Dis~Ds D7~Du 
图 5-23 32 位 微 处 理 器 的 存储 器 组 织 


4. 64 位 存储 器 接口 
64 位 存储 需 系 统 由 8 个 存储 体 组 成 ,每 个 存储 体 的 存储 空间 为 512MB(Pentium) 或 
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8GB(Pentium Pro) ,存储 体 选择 通过 选择 信号 BE; 一 BE。 实现。 如果 要 传送 一 个 64 位 数 ， 
那么 8 个 存储 体 都 被 选中 ;如 果 要 传送 一 个 32 位 数 , 那 么 4 个 存储 体 被 选中 ;车 要 传送 一 个 
16 位 数 , 则 有 两 个 存储 体 被 选中 ;车 传送 的 是 8 位 数 , 只 有 一 个 存储 体 被 选中 。 

64 位 存储 器 组 织 与 前 述 32 位 存储 器 组 织 相 似 ,在 此 不 再 重复 。 图 5-24 给 出 了 
Pentium 微 处 理 器 的 地 址 总 线 与 64、32、16 和 8 位 存储 器 的 接口 示意 图 。 


64 位 
存储 器 


Pentium BE;~BE, 


存储 器 


8 位 


存储 器 


5-24 ”Pentium 微 处 理 器 的 地 址 总 线 与 64、32、16 和 8 位 存储 器 的 接口 


5.5 提高 主 存 读 写 速度 的 技术 


近 几 年 来 , 主 存 技术 一 直 在 不 断 地 发 展 ,从 最 早 使 用 的 DRAM 到 后 来 的 FPM DRAM.、 
EDO DRAM.SDRAM.DDR SDRAM DDR2 SDRAM.DDR3 SDRAM.DDR4 SDRAM 和 
RDRAM, 出 现 了 各 种 主 存 控制 与 访问 技术 ,它们 的 共同 特点 是 使 主 存 的 读 写 速 度 有 了 很 大 
的 提高 。 


S.S.1 主 存 与 CPU 速度 的 匹配 


过 去 , 主 存 的 速度 通常 以 纳 秒 (ns) 表 示 ,而 CPU 速度 总 是 被 表示 为 兆赫 效 (MHz) ,最 
近 一 些 更 快 更 新 的 主 存 也 用 MHz 来 表示 速度 。 

如 果 主 存 总 线 的 速度 与 CPU 总 线 速 度 相等 ,那么 主 存 的 性 能 将 是 最 优 的 。 然 而 通常 
主 存 的 速度 落后 于 CPU 的 速度 ,以 个 人 计算 机 (PC) 为 例 , 在 1998 年 以 前 ,DRAM 的 存 取 
时 间 为 60ns 或 更 大 ,这 相当 于 16. 7MHz 或 更 慢 的 速度 ,而 当时 CPU 的 速度 已 达到 
300MHz 或 更 高 的 速度 ,两 者 之 间 存 在 着 很 大 的 差距 ,这 就 是 为 什么 需要 高 速 缓 冲 存储 咒 
(Cache) 的 原因 ， 

当 1GHz CPU 要 从 133MHz 主 存 读 多 个 字 节 的 数据 时 会 出 现 大 量 的 等 待 状态 ,所 谓 等 
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待 状态 就 是 处 理 器 在 等 竺 数据 就 绪 之 前 必须 执行 的 一 个 额外 "什么 都 不 做 ”的 周期 。 由 于 主 
存 周 期 为 7.5ns,CPU 周期 为 1ns,CPU 需要 执行 6 个 等 竺 周期 ,然后 数据 才 会 在 第 七 个 周 
期 准备 好 。 增 加 等 待 周期 实际 上 是 将 CPU 速度 减 慢 至 主 存 速 度 。 为 了 减少 所 需 的 等 待 周 
期 数 ,许多 系统 开始 引入 新 型 的 存储 芯片 ,这些 存 储 芯片 在 存储 器 总 线 的 性 能 已 与 CPU 总 
线 的 性 能 相差 无 几 。 


S$.S5.2 FPM DRAM 


传统 的 DRAM 是 通过 分 页 技术 进行 访问 的 ,在 存 取 数据 时 ,需要 分 别 输入 一 个 行 地 址 和 
一 个 列 地 址 ,这 会 耗费 时 间 。 快 速 页 模式 随机 存储 器 (Fast Page Mode DRAM,FPM DRAMD) 是 
传统 DRAM 的 改进 型 产品 ,通过 保持 行 地 址 不 变 而 只 改变 列 地 址 ,可 以 对 给 定 行 的 所 有 数据 
进行 更 快 的 访问 。FPM DRAM 的 速度 之 所 以 能 提高 是 基于 这 样 一 个 事实 一 一 计算 机 中 大 量 
的 数据 是 连续 存放 的 。 例 如 ,各 一 个 数据 与 前 一 个 数据 的 行 地 址 相同 , 主 存 控制 硕 就 不 必 再 传 
一 次 行 地 址 ,只 要 再 传 一 个 列 地 址 就 可 以 了 。 这 种 触发 行 地 址 后 连续 输出 列 地 址 的 方式 能 用 
较 少 的 时 钟 周期 读 较 多 的 数据 , 即 存 取 同 一 “页 ”数据 的 速度 与 效率 就 大 大 提高 了 ( 行 地 址 不 变 
时 , 列 地 址 可 寻 址 的 空间 称 为 一 “页 ”, 一 页 通常 为 1024 字 节 的 整数 倍 )。 

FPM DRAM 还 文 持 突 发 模式 访问 ,所 谓 突 发 模式 是 指 对 一 个 给 定 的 访问 在 建立 行 和 
列 地 址 之 后 ,可 以 访问 后 面 3 个 相 邻 的 地 址 ,而 不 需要 额外 的 延迟 和 等 待 状态 。 一 个 突 发 访 
问 通 稼 限制 为 4 次 正常 访问 。 为 了 描述 这 个 过 程 , 经 常 以 每 次 访问 的 周期 数 表 示 计 时 。 一 
个 标准 DRAM 的 典型 突 发 模式 访问 表示 为 x-y-y-y ,ZX 是 第 一 次 访问 的 时 间 ( 延 迟 加 上 周期 
数 ),y 表示 后 面 每 个 连续 访问 所 需 的 周期 数 。 标 准 的 FPM DRAM 可 获得 5-3-3-3 的 突 发 
模式 周期 。 

显然 ,FPMD RAM 的 这 种 工作 方式 需要 存储 心 片 和 主 存 控 制 颖 共同 配合 才能 完成 。 
在 Pentium 主板 上 , 主 存 控制 器 被 制作 在 主板 的 芯片 组 中 。 随 着 技术 的 成 熟 ,FPM DRAM 
的 访问 时 间 也 在 不 断 缩短 ,从 120ns 缩短 到 60ns。 

FPM DRAM 内 存 条 主要 采用 72 线 的 SIMM 封装 ,其 存 取 速度 一 般 为 60 一 100ns。 


5.5.3 上 DO DRAM 


扩展 数据 输出 DRAM(Extended Data Output DRAM,EDO DRAM) 是 在 FPM DRAM 
基础 上 加 以 改进 的 存储 器 控制 技术 。 传 统 的 DRAM 和 FPM DRAM 在 存 取 每 一 数据 时 , 输 
入 行 地 址 和 列 地 址 后 必须 等 待 电路 稳定 ,然后 才能 有 效 地 读 写 数据 ,而 下 一 个 地 址 必须 等 待 
这 次 读 写 周期 完成 才能 输出 。 而 EDO 输出 数据 在 整个 CAS 周期 都 是 有 效 的 (包括 预 充电 
时 间 在 内 ) ,EDO 不 必 等 待 当 前 的 读 写 周期 完成 即 可 启动 下 一 个 读 写 周期 , 即 可 以 在 输出 一 
个 数据 的 过 程 中 准备 下 一 个 数据 的 输出 。EDO DRAM 采用 一 种 特殊 的 主 存 读 出 控制 逻 
辑 ,在 读 写 一 个 存储 单元 时 同时 启动 下 一 个 (连续 ) 存 储 单元 的 读 写 周期 ,从 而 节省 了 重 选 地 
址 的 时 间 ,提高 了 读 写 速度 。 

EDO DRAM 可 获得 5-2-2-2 的 突 发 模式 周期 ,奋进 行 4 个 主 存 传输 ,需要 总 共 11 个 系 
统 周 期 ,而 FPM DRAM 的 突 发 模式 周期 为 5-3-3-3 ,总 共 需 要 14 个 周期 。 与 FPM DRAM 
相 比 ,EDO DRAM 的 性 能 改善 了 22%% ,而 其 制造 成 本 与 FPM DRAM 相近 。 

FPM 和 EDO 两 者 的 芯片 制作 技术 其 实 是 相同 的 ,不 同 的 是 EDO 所 增加 的 机 制 必须 在 
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世 片 组 的 支持 下 将 发 送 的 数据 信号 的 处 理 时 间 缩 短 , 以 加 快 系统 的 整体 执行 效率 。EDO 
DRAM 内 存 条 主要 采用 72 线 的 SIMM 形式 封装 ,也 有 少 部 分 采用 168 线 的 DIMM 封装 ， 
工作 电压 为 5V, 存 取 时 间 为 50 一 70ns。 


S$.S.4 SDRAM 


前 面 介绍 的 几 种 DRAM 主 存 都 属于 "* 非 同步 存 取 的 存储 希 ”, 即 它们 的 工作 速度 并 没 
有 和 系统 时 钟 同步 , 存 取 数 据 时 ,系统 必须 等 待 奋 干 时 钟 周期 才能 接收 和 发 送 数 据 。 例 如 ， 
EDO DRAM 必须 等 待 2 个 时 钟 周 期 ,FPM DRAM 则 必须 等 待 3 个 时 钟 周期 ,这 种 等 待 制 
约 了 系统 的 数据 传送 速率 。 通 常 ,FPM DRAM 和 EDO DRAM 的 速度 不 能 超过 66MHz。 

同步 动态 随机 存储 天 (Synchronous DRAM,SDRAM) 是 一 种 与 主 存 总 线 运 行 同步 的 
DRAM。SDRAM 在 同步 脉冲 的 控制 下 工作 ,取消 了 主 存 等 待 时 间 , 减 少 了 数据 传送 的 延迟 
时 间 ,因而 加 快 了 系统 速度 。SDRAM 仍然 是 一 种 DRAM ,起 始 延 开 仍 然 不 变 , 但 总 的 周期 
时 间 比 FPM 或 EDO 快 得 多 。SDRAM 突 发 模式 可 达到 5-1-1-1, 即 进行 4 个 主 存 传 输 , 仅 
需 8 个 周期 , 比 EDO 快 将 近 20%。 

SDRAM 的 基本 原理 是 将 CPU 和 RAM 通过 一 个 相同 的 时 钟 锁 在 一 起 ,使 得 RAM 和 
CPU 能 够 共享 一 个 时 钟 周 期 ,以 相同 的 速度 同步 工作 。 就 是 说 ,SDRAM 在 开始 的 时 候 要 
多 花 一 些 时 间 ,但 在 以 后 ,每 1 个 时 钟 可 以 读 写 1 个 数据 ,做 到 了 所 有 的 输入 输出 信号 与 系 
统 时 钟 同步 。 这 已 经 接近 主板 上 的 同步 Cache 的 3-1-1-1 水 准 。 一 般 来 说 ,在 系统 时 钟 为 
66MHz 时 ,SDRAM 与 EDO DRAM 相 比 ,显示 不 出 其 优点 ,但 当 系 统 时 钟 增 加 到 100MHz 
以 上 ,SDRAM 的 优点 便 很 明显 。 

SDRAM 采用 新 的 双 存 储 体 结构 ,内 含 两 个 交错 的 存储 矩阵 ,允许 两 个 主 存 页 面 同时 打 
开 , 当 CPU 从 一 个 存储 窍 阵 访 问 数据 的 同时 ,在 主 存 控 制 硕 作用 下 另 一 个 存储 矩阵 已 准备 
好 读 写 数据 。 通 过 两 个 存储 矩阵 的 紧密 配合 , 存 取 效 率 得 到 成 倍 提高 。 

SDRAM 普遍 采用 168 线 的 DIMM 封装 ,速度 通常 以 MHz 来 标定 ,为 降低 功 耗 ,一 般 
使 用 3. 3V 电压 。SDRAM 支持 PC 66/100/133/150 等 不 同 的 规范 ,表示 其 的 工作 频率 分 
别 为 66MHz、100MHz、133MHz 和 150MHz, 能 与 相应 的 CPU 同步 运行 ,可 提高 整 机 性 能 
5%~10%。 


S$S.S.S DDR SDRAM 


双 数 据 传 输 率 同步 动态 随机 存储 器 (Double Data Rate SDRAM,DDR SDRAM) 也 可 以 
说 是 SDRAM 的 升级 版 本 ,DDR SDRAM 运用 了 更 先进 的 同步 电路 , 它 与 SDRAM 的 主要 
区 别 是 : DDR SDRAM 不 仅 能 在 时 钟 脉冲 的 上 升 沿 读 出 数据 而 且 还 能 在 下 降 沿 读 出 数据 ， 
不 需要 提高 时 钟 频率 就 能 加 倍 提高 SDRAM 的 速度 。 

DDR SDRAM 的 频率 可 以 用 工作 频率 和 等 效 传输 频 率 两 种 方式 表示 ,工作 频率 是 内 存 
颗粒 实际 的 工作 频率 (又 称 核心 频率 ) ,但 是 由 于 DDR 可 以 在 脉冲 的 上 升 沿 和 下 降 沿 都 传 
输 数据 ,因此 传输 数据 的 等 效 传输 频率 是 工作 频率 的 两 倍 。 由 于 外 部 数据 总 线 的 宽度 为 
64 位 ,所 以 数据 传输 率 ( 带 宽 ) 等 于 等 效 传 输 频 率 X8。 

DDR SDRAM 基本 上 可 完全 沿用 SDRAM 现 有 的 生产 体系 ,其 生产 成 本 与 SDRAM 相 
差 不 大 。DDR 内 存 条 的 物理 大 小 和 标准 的 DIMM 一 样 ,区 别 仅 在 于 内 存 条 的 线 数 。 标 准 
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的 SDRAM 有 168 线 ( 两 个 小 缺口 ) ,而 DDR SDRAM 有 184 线 ( 多 出 的 16 个 线 占 用 了 空 
间 , 故 只 有 1 个 小 缺口 )。DDR RDRAM 可 以 工作 在 2. 5V 的 低 电 压 环 境 下 。 

DDR SDRAM 的 标准 主要 有 DDR 200、DDR 266、DDR 333 和 DDR 400 等 ,分 别 对 应 
PC1600/PC2100/PC2700/PC3200 几 种 规范 ,以 DDR 266 为 例 , 它 的 工作 频率 为 133MHz， 
等 效 传输 频率 为 266MHz(133MHzX2) ,传输 带宽 为 2.1GB/s(266X8) 。 


$S.5.6 DDR2 .DDR3.DDR4 和 DDRS SDRAM 


在 DDR 之 后 ,内 存 的 家 族 中 又 陆续 出 现 了 DDR2、DDR3、DDR4,DDR5 的 原型 也 已 经 
面世 。 


1. DDR2 SDRAM 


DDR2(Double Data Rate 2)SDRAM 与 上 一 代 DDR SDRAM 技术 标准 最 大 的 不 同 在 
于 ,虽然 同 是 采用 了 在 时 钟 的 上 升 沿 和 下 降 沿 同时 进行 数据 传输 的 基本 方式 ,但 DDR2 
SDRAM 却 拥有 两 位 于 上 一 代 DDR SDRAM 的 预 读 取 能 力 ( 即 4 位 数据 读 预 取 )。 换 句 话 
说 ,DDR2 SDRAM 每 个 时 钟 能 够 以 4 倍 于 外 部 总 线 的 速度 谈 写 数据 , 即 在 同样 100MHz 的 
工作 频率 下 ,DDR 的 实际 频率 为 200MHz, 而 DDR2 则 可 以 达到 400MHz。 

目前 ,已 有 的 DDR2 分 为 DDR2 400、DDR2 533、DDR2 667、DDR2 800 等 ,其 核心 频率 
分 别 为 100MHz、133MHz、166MHz 和 200MHz, 等 效 的 数据 传输 频率 分 别 为 400MHz、 
533MHz、667MHz 和 800MHz, 其 对 应 的 传输 带宽 分 别 为 3. 2GB/s、4. 3GB/s、5. 3GB/s 和 
6. 4GB/s ,对 应 PC2 3200、PC2 4300、PC2 5300、PC2 6400 几 种 规范 。 

DDR2 内 存 条 采用 240 线 DIMM ,工作 电压 1. 8V ,相对 于 DDR 标准 的 2.5V 下 降 了 不 
少 , 从 而 降低 了 功 耗 和 发 热量 。 


2. DDR3 SDRAM 


DDR3 SDRAM 可 以 看 作 是 DDR2 的 改进 版 ,DDR2 的 预 取 设计 位 数 是 4 位 , 即 DRAM 
内 核 的 频率 只 有 接口 频率 的 1/4, 而 DDR3 的 预 取 设计 位 数 提升 至 8 位 ,其 DRAM 内 核 的 
频率 达到 了 接口 频率 的 1/8。 同 样 运行 在 200MHz 核心 工作 频率 下 ,DDR2 的 等 效 传输 频 
率 为 800MHz ,而 DDR3 的 等 效 传输 频率 可 以 达到 1600MHz。 

依照 JEDEC( 电 子 设备 工程 联合 委员 会 ) 的 标准 ,DDR3 在 800 一 2133MHz 下 运行 ,这 
是 DDR2 频率 的 两 倍 。DDR3 SDRAM 分 为 DDR3 800、DDR3 1066、DDR3 1333 、DDR3 
1600 等 ,其 核心 频率 仍 分 别 为 100MHz、133MHz、166MHz 和 200MHz, 等 效 的 数据 传输 频 
率 分 别 为 800MHz、1066MHz、1333MHz 和 1600MHz, 其 对 应 的 传输 带宽 分 别 为 
6.4GB/s、8.6GB/s、10.6GB/s 和 12.8GB/s, 对 应 PC3 6400、PC3 8600、PC3 10600、PC3 
12800 几 种 规范 。 

DDR3 内 存 条 仍 采 用 240 线 DIMM, 电 压 有 标准 版 1.5V、 节 能 版 1. 35V 两 种 , 相 比 
DDR2 来 说 可 以 节约 大 约 16% 的 电能 。 目 前 ,DDR3 仍然 被 用 作 微 机 的 内 存 条 。 


3. DDR4 SDRAM 


2012 年 9 月 底 ,JEDEC 正式 公布 了 DDR4 内 存 标准 规范 ,由 于 数据 预 取 的 增加 变 得 越 
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来 越 困 难 , 所 以 DDR4 推出 了 bank group 设计 。 每 个 bank group 可 独立 读 写 数据 ,使 得 内 
部 的 数据 吞吐 率 大 大 提升 。DDR4 架构 上 采用 了 8 位 预 取 的 bank group 分 组 ,包括 使 用 2 
个 或 4 个 可 选择 的 bank group 分 组 ,如果 内 存 内 部 设计 了 2 个 独立 的 bank group ,相当 于 
每 次 操作 16 位 数据 ,变相 的 把 内 存 预 取 值 提高 到 16 位 ,如 果 是 4 个 独立 的 bank group, 相 
当 于 每 次 操作 32 位 数据 ,变相 的 把 内 存 预 取 值 提高 到 32 位 。 

DDR4 内 存 标 准 规定 最 低 是 DDR4 1600, 即 从 1600MHz 开始 运行 ,这 将 是 DDR3 频率 
的 两 倍 。 例 如 ,DDR4 3200 的 带宽 为 25.6GB/s, 比 DDR3 1866 高 出 了 70%。 

DDR4 内 存 条 的 引 脚 数 从 DDR3 的 240 线 增加 至 284 线 ,内存 条 的 外 观 变化 明显 , 金 手 
指 变 成 弯曲 状 , 以 保证 与 内 存 搬 槽 点 有 足够 的 接触 面 , 且 中 间 的 凸 起 部 分 与 内 存 插 权 产生 足 
够 的 摩擦 力 以 稳定 内 存 。 工 作 电 压 下 降 至 1.2V、1.1V, 甚 至 有 1.05V 的 超 低 压 节能 版 。 目 
前 ,DDR4 已 成 为 主流 微机 的 标准 配置 。 

DDR SDRAM 内 存 的 发 展 趋势 如 表 5-7 所 示 。 


表 5-7 DDR SDRAM 内 存 的 发 展 趋势 
频率 


Z 


oR VN 
DDR2 本 而 硬 加 本 六 回国 硬 面 硬 面 面 面 
PR | YY 
ppR | | | MMX 


4. DDRS SDRAM 


目前 ,JEDEC 组 织 正在 制订 DDR5 内 存 标准 规范 ,DDR5 的 原型 也 已 经 开始 展示 
4400MHz 对 于 DDR5 来 说 可 能 只 是 起 步 ,预计 最 终 可 以 达到 6400MHz 左右 , 相 比 目前 的 
DDR4 ,频率 提升 了 近 一 倍 。DDR5 的 变化 不 仅 是 频率 的 提高 ,因为 允许 加 入 内 部 ECC 来 制 
造 16Gb、32Gb 颗粒 ,单条 容量 也 会 大 大 提升 。 

根据 业内 人 士 预测 ,DDR5 内 存 预计 将 于 2020 年 开始 面向 服务 器 和 数据 中 心 等 企业 用 
户 供 贷 , 面 癌 消 费 市 场 的 DDR5 内 存 则 还 需要 等 待 支 持 DDR5 内 存 的 处 理 器 和 主板 出 现 ， 
才 会 正式 商用 ,预计 需要 等 到 2022 年 。 


S$S.S.7 Rambus DRAM 


Rambus DRAM(RDRAM) ,是 继 SDRAM 之 后 的 新 型 高 速 动态 随机 存储 器 。 由 美国 
Rambus 公司 研发 的 RDRAM 在 内 部 结构 上 进行 了 重新 设计 ,并 采用 了 新 的 信号 接口 技术 ， 
其 对 外 接口 也 不 同 于 以 前 的 DRAM。 该 内 存 规范 是 Intel 公司 与 Rambus 公司 共同 定制 
的 , 旨 在 创造 市 面 上 最 高 速 的 内 存 产 品 。 

使 用 FPM/EDO 或 SDRAM 的 传统 主 存 系统 称 为 宽 通道 系统 ,它们 的 主 存 通 道 和 处 理 
器 的 数据 总 线 一 样 宽 。RDRAM 却 是 一 种 窗 通 道 系统 , 它 一 次 只 传输 16 位 数据 (加 上 两 个 
可 选 的 校 验 位 ), 但 速度 却 快 得 多 。 目 前 ,RDRAM 的 容量 一 般 为 64Mb、72Mb、128Mb、 
144Mb, 组 织 结构 为 4MX16 位 4MX18 位 .8MX16 位 .8MX18 位 (18 位 的 组 织 结构 允许 
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进行 ECC 检测 ) 。 

RDRAM 依 徘 其 极 高 的 工作 频率 ,通过 减少 每 个 周期 的 数据 量 来 简化 操作 。RDRAM 
的 时 钟 频率 可 达到 400MHz, 由 于 采用 双 沿 传输 ,使 原 有 的 400MHz 变 为 800MHz。 
Rambus 结构 的 带宽 视 Rambus 通路 的 个 数 而 定 , 特 是 单 通路 ,800MHz 的 RDRAM 带宽 为 
800MHzX16b 王 8 二 1. 6GB/s, 奉 是 两 个 通路 , 则 可 提升 为 3.2GB/s, 夺 是 4 个 通路 的 话 , 将 
达到 6. 4GB/s。 而 DDR 133 的 带宽 为 133MHzX 64b 王 8 二 1.06GB/s, DDR 266 则 为 
2. 1GB/s。 

由 于 是 全 新 的 设计 ,需要 用 RIMM 插 槽 与 发 片 组 配合 。RDRAM 总 线 是 一 条 经 过 总 线 
上 所 有 设备 (RDRAM 芯片 ) 和 模块 的 连接 线路 ,每 个 模块 在 相对 的 两 端 有 输入 和 输出 引 
脚 ,时 钟 信号 需 依 次 流 过 每 个 RIMM 槽 ,然后 再 通过 每 个 RIMM 模 返回 。 因 此 ,任何 不 含 
RDRAM 必 片 的 RIMM 插 槽 必须 填 入 一 个 连接 模块 即 Rambus 终结 硕 以 保证 路 径 是 完 
整 的 。 

Rambus 虽然 具有 高 带宽 的 优势 ,但 只 有 在 采用 Pentium 4 后 的 高 性 能 微机 上 这 种 优势 
才能 得 到 适当 的 发 挥 。 目 前 ,RDRAM 主要 有 300MHz、356MHz 和 400MHz 3 种 速率 的 产 
品 ,更 高 速率 (533MHz) 的 产品 也 已 经 开发 成 功 。 由 于 RDRAM 的 双 沿 传输 等 同 于 速率 的 
加 倍 , 所 以 常 把 上 述 3 种 速率 的 RDRAM 称 为 PC-600、PC-700( 实 际 上 是 PC-711) 和 PC- 
800 主 存 。 

此 外 ,RDRAM 还 有 一 个 特点 ,就 是 它 的 行 地 址 与 列 地 址 的 寻 址 总 线 是 各 自分 离 的 独 
立 总 线 , 这 就 意味 着 行 与 列 的 选 址 几乎 在 同一 时 间 内 进行 ,从 而 进一步 提高 了 工作 效率 ;也 
正 因 为 拥有 这 一 优势 ,使 得 RDRAM 不 仅 可 以 弥补 它 在 寻 址 时 间 上 比 传统 的 SDRAM 慢 的 
缺点 ,而且 在 实际 工作 中 所 表现 出 来 的 性 能 更 好 。 

但 是 ,Rambus 最 终 并 没有 得 到 市 场 的 认可 , 究 其 原因 ,就 是 因为 Rambus 内 存 高 昂 的 
售 价 以 及 “巨大 ”的 发 热量 ,加 上 Rambus DRAM 必须 安装 两 条 才能 够 使 用 ,这 就 大 大 提高 
了 这 种 内 存 的 使 用 门槛 。 最 终 ,Rambus DRAM 没有 经 受 住 市 场 的 考验 ,被 价格 更 低 的 
DDR SDRAM 踩 在 了 脚下 。 


S.S.8 多 通道 内 存 技 术 


多 通道 内 存 技术 是 解决 CPU 总 线 市 宽 与 内 存 市 宽 巴 盾 的 低 价 .高 性 能 方案 ,其 实质 上 
是 一 种 多 通道 内 存 控制 和 管理 技术 ,与 内 存 目 号 无 关 。 目 前 双 通 道内 存 技 术 和 三 通道 内 存 
技术 已 在 微机 上 广泛 使 用 ,四 通道 内 存 技术 也 已 经 出 现 ,只 不 过 目前 价格 还 非常 昂贵 ,大 多 
在 服务 器 和 工作 站 中 运用 。 


1. 双 通 道内 存 技术 


双 通 近 内 存 技术 ,就 是 在 北桥 心 片 组 里 制作 两 个 内 存 控 制 右 ,这 两 个 内 存 控制 右 是 可 以 
相互 独立 工作 的 。 在 这 两 个 内 存 通道 上 ,CPU 可 以 分 别 寻 址 . 读 取 数据 ,从 而 可 以 使 内 存 的 
齐 宽 增加 一 倍 , 理 论 上 数据 存 取 速 度 也 相应 增加 一 倍 。 

双 通道 DDR 有 两 个 64 位 内 存 控制 硕 , 双 64 位 内 存 体系 所 提供 的 带宽 等 同 于 一 个 128 
位 内 存 体系 所 提供 的 市 宽 , 但 是 二 者 所 达到 效果 却 是 不 同 的 。 因 为 双 通 道 体系 的 两 个 内 存 
控制 大 是 独立 的 .具备 互补 性 的 智能 内 存 控制 融 ,两 个 内 存 控制 硕 都 能 够 在 彼此 间 堆 等待 时 
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间 的 情况 下 同时 运行 。 例 如 , 当 控 制 颖 B 准备 进行 下 一 次 存 取 内 存 的 时 候 , 控 制 副 A 就 在 
读 写 主 内 存 , 反 之 亦 然 。 两 个 内 存 控制 大 的 这 种 互补 "天 性 ”, 可 以 让 有 效 等 待 时 间 缩 减 
50% ,从 而 使 内 存 的 带宽 翻 了 一 番 。 

由 于 双 通 道内 存 技术 将 内 存 位 宽 扩 大 到 128 位 ,如 使 用 双 通 道 DDR 400 内 存 , 其 内 存 
带宽 为 400MHzX128b 二 8=6. 4GB/s; 如 使 用 双 通 道 DDR2 800 内 存 , 其 内 存 带 宽 将 达到 
800MHzX128b 二 8 王 12.8GB/s。 

打开 双 通 道 模式 必须 要 主板 的 北桥 芯片 或 处 理 需 支持 。 早 期 , 双 通 道 技 术 对 内 存 条 的 
要 求 十 分 严 苛 , 两 条 规格 (容量 .时 钟 频 率 、 延 迟 、 颗 粒 、 品 牌 \ 周 期 ) 必 须 相 同 。 现 在 由 于 采用 
了 不 对 称 双 通道 ( 即 采 用 了 两 个 统一 定 址 空间 的 存储 器 控制 器 ) ,所 以 可 以 支持 使 用 两 条 不 
同 规格 的 内 存 条 。 

并 非 有 支持 双 通 道 的 主板 上 安装 两 条 内 存 条 就 能 运行 工作 ,还 需要 正确 的 安装 。 只 有 
当 两 组 通道 上 都 同时 安装 了 内 存 条 时 ,才能 使 内 存 工 作 在 双 通 道 模 式 下 ,否则 只 能 工作 在 单 
通道 模式 。 由 于 各 家 主板 不 同 ,因此 必须 要 按照 主板 说 明 书 以 正确 方式 安装 。 


2. 三 通道 内 存 技术 


随 着 Intel Core 17 平台 发 布 ,三 通道 内 存 技 术 应 运 而 生 。Core 17 处 理 需 抛弃 了 前 端 总 
线 而 采用 QPI 总 线 , 同 时 将 内 存 控制 从 北桥 中 成 功 转移 到 CPU 中 ,内 存 与 处 理 右 之 间 采 用 
点 对 点 连接 设计 ,内 存 里 的 数据 可 由 内 存 总 线 直接 传送 给 处 理 器 ,使 得 内 存 读 取 延迟 大 幅 

三 通道 内 存 技术 实际 上 是 双 通 道内 存 技术 的 后 续 技 术 发 展 , 三 通道 将 内 存 总 线 位 宽 扩 
大 到 了 64bX3 王 192b, 同 时 采用 DDR3 1333 内 存 ,因此 其 内 存 总 线 带 宽 达 到 了 1333MHzX 
192b 二 8 三 32GB/s ,内 存 带 宽 得 到 巨大 的 提升 。 三 通道 内 存 的 理论 性 能 也 能 比 同 频率 双 通 
道内 存 提升 50% 以 上 。 

对 于 文 持 三 通道 内 存 的 主板 ,无论 是 4 根 内 存 插 模 还 是 6 根 内 存 插 槽 的 产品 ,要 想 实现 
三 通道 模式 ,只 要 将 同色 的 三 根 内 存 插 槽 插 上 内 存 条 即 可 ,系统 便 会 自动 识别 并 进入 三 通道 
模式 。 但 是 ,如 果 插 上 非 3 条 或 者 非 6 条 的 内 存 ,系统 会 自动 进入 单 通道 模式 。 


5.6 多 体 交 义 存 储 技术 


目前 , 主 存 的 存 取 速 度 已 成 为 计算 机 系统 的 瓶颈 ,除去 通过 寻找 高 速 元 件 来 提高 访问 速 
度 外 ,也 可 以 采用 多 个 存储 天 并 行 工 作 , 并 且 用 交叉 访问 技术 来 提高 存储 融 的 访问 速度 。 


S.6.1 并 行 访问 存储 器 


常规 的 主 存 是 单 体 单字 存储 器 ,只 包含 一 个 存储 体 。 在 高 速 的 计算 机 中 ,普遍 采用 并 行 
主 存 系统 , 即 在 一 个 存 取 周 期 内 可 以 并 行 读 出 多 个 字 , 依 徘 整 体 信 息 否 吐 率 的 提高 ,以 解决 
CPU 与 主 存 之 间 的 速度 匹配 问题 。 

多 个 并 行 工 作 的 存储 需 共 有 一 套 地 址 寄存 顺和 详 码 电路 , 按 同 一 地 址 并 行 地 访问 各 月 
的 对 应 单元 。 例 如 ,CPU 送出 地 址 A, 则 个 存储 右 中 的 所 有 A 单元 同时 被 选中 。 假 设 每 
个 存储 器 的 字 长 为 包 位 , 则 同时 访问 nXw 位 。 也 可 以 将 这 个 存储 器 看 作 一 个 大 存储 器 ， 
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一 次 访问 n 个 字 , 故 称 为 单 体 多 字 并 行 存储 系统 ,如 图 5-25 所 示 。 

并 行 访问 存储 带 按 地 址 在 一 个 存 取 周期 内 可 读 出 nXw 位 的 指令 或 数据 ,使 主 存 市 宽 
提高 n 倍 。 显 然 ,采用 这 种 方法 的 前 提 是 : 指令 和 数据 在 主 存 中 必须 是 连续 存放 的 ,一 旦 遇 
到 转移 指令 ,或 者 操作 数 不 能 连续 存放 ,这 种 方法 的 效果 就 不 明显 了 。 并 行 访问 存储 天 的 主 
要 缺点 是 访问 主 存 的 冲突 大 。 


5.6.2 交叉 访问 存储 器 


交 义 访问 存储 器 中 有 多 个 容量 相同 的 存储 模块 (存储 体 ) ,而 且 各 存储 模块 具有 各 上 自 独 
立 的 地 址 寄存 器 . 读 写 电 路 和 数据 寄存 器 ,这 就 是 多 体系 统 。 各 个 存储 体能 并 行 工 作 ,又 能 
交叉 工作 。 

多 体 交 又 访 问 存 储 器 如 图 5-26 所 示 。 存 储 器 地 址 寄存 器 的 低位 部 分 经 过 译 码 选择 不 
同 的 存储 体 , 而 高 位 部 分 则 指向 存储 体内 的 存储 字 。 现 以 由 4 个 分 体 组 成 的 多 体 交 又 存储 
右 为 例 , 说 明 常 用 的 编 址 方式 。4 个 分 体 Mo、Mi、M、M; 的 编 址 序列 如 表 5-8 所 示 , 称 之 为 
模 4 交叉 编 址 序列 。 


地 址 译 码 


地 址 译 码 ”| 地址 译 码 


地 址 模块 号 
图 5-25 单 体 多 字 并 行 存储 系统 图 5-26 多 体 交 叉 访问 存储 器 


表 5-8 模 4 交叉 编 址 序列 


模 块 号 地 址 编 址 序列 对 应 二 进 制 地 址 的 最 低 两 位 


Mo 0,4,8,12,.… ,4i 十 0 ,…… 00 
Mi 1,5,9,13,° ,4iT1,°*° 01 
M, 2,6,10,14,.… ,4i 十 2,*… 10 
M; 3,7,11,15,°° ,4i1T|3,°° | 


在 这 种 交叉 存储 器 中 ,连续 的 地 址 分 布 在 相 邻 的 存储 体 中 ,而 同一 存储 体内 的 地 址 都 是 
不 连续 的 。 这 种 编 址 方式 又 称 为 横向 编 址 。 

多 体 交叉 访问 存储 器 采用 分 时 启动 的 方法 ,可 以 在 不 改变 每 个 模块 存 取 周期 的 前 提 下 ， 
提高 整个 主 存 的 速度 。 例 如 ,有 4 个 模块 ,在 第 一 个 存储 周期 的 开始 时 刻 启动 模块 M, ,在 
1 31m 时 刻 分 别 启动 模块 Mi .Ms .M; ,图 5-27 示意 了 模 4 交叉 存 取 的 时 间 关系 。 


在 4 个 分 体 完 全 并 行 的 理想 情况 下 ,整个 主 存 的 有 效 周期 缩小 到 原来 模块 存 取 周期 的 二 ， 
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数据 传送 的 平均 速度 提高 到 原来 的 4 售 。 
”存储 周期 ， 


图 5-27 模 4 交叉 存 取 分 时 工作 


但 是 在 实际 应 用 中 , 当 出 现 数据 相关 和 程序 转移 时 ,将 破坏 并 行 性 ,不 可 能 达到 上 述 理 
想 值 。 

注意 : 交叉 访问 存储 器 要 求 存储 体 的 个 数 是 2 的 整数 千 , 即 必须 是 2、 4、8、16… 个 ,而 且 
任 一 分 体 出 现 故障 都 将 影响 整个 地 址 空间 的 所 有 区 域 。 


5.7 高 速 缓冲 存储 器 


主 存 速度 的 提高 始终 跟 不 上 CPU 的 发 展 。 据 统计 ,CPU 的 速度 平均 每 年 提高 60%， 
而 组 成 主 存 的 DRAM 的 速度 平均 每 年 只 改进 7%。 由 SRAM 组 成 的 高 速 缓冲 存储 器 的 运 
行 速度 则 接近 甚至 等 于 CPU 的 速度 。 


S.7.1 高 速 缓存 工作 原理 
1. 程序 的 局 部 性 原理 


程序 的 局 部 性 有 两 个 方面 的 含义 : 时 间 局 部 性 和 空间 局 部 性 。 时 间 局 部 性 是 指 如 果 一 
个 存储 单元 被 访问 , 则 可 能 该 单元 会 很 快 被 再 次 访问 。 这 是 因为 程序 存在 着 循环 。 空间 局 
部 性 是 指 如 果 一 个 存储 单元 被 访问 , 则 该 单元 邻近 的 单元 也 可 能 很 快 被 访问 。 这 是 因为 程 
序 中 大 部 分 指令 是 顺序 存储 顺序 执行 的 ,数据 一 般 也 是 以 向量 数组 、 树 、 表 等 形式 复 聚 地 
存储 在 一 起 的 。 

高 速 缓冲 技术 就 是 利用 程序 的 局 部 性 原理 ,把 程序 中 正在 使 用 的 部 分 存放 在 一 个 高 速 
的 容量 较 小 的 Cache 中 ,使 CPU 的 访 存 操作 大 多 数 针对 Cache 进行 ,从 而 使 程序 的 执行 速 
度 大 大 提高 。 

2. Cache 的 基本 结构 

图 5-28 给 出 了 Cache 的 基本 结构 。Cache 和 主 存 都 被 分 成 硅 干 个 大 小 相等 的 块 ， 
每 块 由 硅 干 字 节 组 成 。 由 于 Cache 的 容量 远 小 于 主 存 的 容量 ,所 以 Cache 中 的 块 数 要 
远 少 于 主 存 中 的 块 数 , 它 保存 的 信息 只 是 主 存 中 最 急需 执行 的 寿 干 块 的 副本 。 用 主 存 
地 址 的 块 号 字段 访问 Cache 标记 ,并 将 取出 的 标记 和 主 存 地 址 的 标记 字段 相 比 较 , 硅 相 
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等 ,说明 访问 Cache 有 效 , 称 Cache 命中 ; 香 不 相等 ,说明 访问 Cache 无 效 , 称 Cache 不 命 


中 或 失效 。 


来 自 CPU 


post 5 


| 


标记 


Cache 地 址 


访 数据 
去 CPU 
或 来 自 CPU 
5-28 ”Cache 的 基本 结构 


5.7.2 Cache 的 读 写 操作 
1.Cache 的 读 操作 


当 CPU 发 出 读 请 求 时 ,如 果 Cache 命中 ,就 直接 对 Cache 进行 读 操 作 , 与 主 存 无 关 ; 如 
果 Cache 不 命中 , 则 仍 需 访问 主 存 ,并 把 该 块 信息 一 次 从 主 存 调 入 Cache 内 。 硅 此 时 Cache 
已 满 , 则 必须 根据 某 种 蔡 换 算法 ,用 这 个 块 蔡 换 掉 Cache 中 原来 的 某 块 信息 。 


2. Cache 的 写 操作 


由 于 Cache 中 保存 的 只 是 主 存 的 部 分 副本 ,这 些 副 本 与 主 存 中 的 内 容 能 否 保持 一 致 ,是 
Cache 能 否 可 靠 工 作 的 一 个 关键 问题 。 当 CPU 发 出 写 请 求 时 ,如 果 Cache 命中 ,有 可 能 会 
过 到 Cache 与 主 存 中 的 内 容 不 一 致 的 问题 。 例 如 ,由 于 CPU 写 Cache, 把 Cache 某 单 元 中 
的 内 容 从 X 修改 成 了 X ,而 主 存 对 应 单元 中 的 内 容 仍 然 是 X, 没 有 改变 。 所 以 如 果 Cache 
命中 ,需要 进行 一 定 的 写 处 理 , 处 理 的 方法 有 : 写 直 达 法 和 写 回 法 , 详 见 5.7.5 节 。 

如 果 写 Cache 不 命中 ,就 直接 把 信息 写 入 主 存 ,并 有 两 种 处 理 方法 : 

不 按 写 分 配 法 , 即 只 把 所 要 写 的 信息 写 入 主 存 。 

@ 按 写 分 配 法 , 即 在 把 所 要 写 的 信息 写 入 主 存 后 还 把 这 个 块 从 主 存 中 读 和 人 Cache。 


5.7.3 地 址 映像 


在 Cache 中 ,地 址 映像 是 指 把 主 存 地 址 空间 映像 到 Cache 地 址 空间 ,也 就 是 把 存放 在 主 
存 中 的 程序 按照 某 种 规则 装 入 Cache 中 。 地 址 映像 的 方法 有 3 种 : 全 相 联 映像 .直接 映像 
和 组 相 联 映像 。 
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1. 全 相 联 映像 


全 相 联 映像 就 是 让 主 存 中 任何 一 个 块 均 可 以 映像 装 入 到 Cache 中 任何 一 个 块 的 位 置 
上 ,如 图 5-29(a) 所 示 。 全 相 联 映像 方式 比较 灵活 ,Cache 的 块 冲突 概率 最 低 、 空 间 利用 率 最 
高 ,但 是 地 址 变换 速度 慢 , 而 且 成 本 高 ,实现 起 来 比较 困难 。 
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5-29 3 种 映像 规则 


2. 直接 映像 


直接 映像 是 指 主 存 中 的 每 一 个 块 只 能 被 放置 到 Cache 中 唯一 的 一 个 指定 人 位置, 大 
这 个 位 置 已 有 内 容 , 则 产生 块 冲突 ,原来 的 块 将 无 条 件 地 被 蔡 换 出 去 。 直 接 映像 方式 
是 最 简单 的 地 址 映像 方式 ,成 本 低 , 易 实现 ,地 址 变换 速度 快 ,而 且 不 涉及 其 他 两 种 映 
像 方 式 中 的 替换 算法 问题 。 但 是 ,这 种 方式 不 够 灵活 ,Cache 的 块 冲 突 概率 最 高 ,空间 
利用 率 最 低 。 

直接 映像 规则 如 图 5-29(b) 所 示 。 例 如 , 主 存 的 第 0 块 .第 8 块 ,只 能 映像 到 Cache 的 第 
0 块 ;而 主 存 的 第 1 块 . 第 9 块 ,只 能 映像 到 Cache 的 第 1 块 ; 等 等 。 直 接 映像 的 关系 可 定 
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义 为 : 
R= A000d2 
式 中 ,K 为 Cache 的 块 号 ;I 为 主 存 的 块 号 ;2° 为 Cache 块 数 。 


3. 组 相 联 映像 


组 相 联 映像 将 Cache 空间 分 成 大 小 相同 的 组 ,让 主 存 中 的 一 块 直接 映像 狼人 入 Cache 中 
对 应 组 的 任何 一 块 位置 上 , 即 组 间 有 采取 直接 映像 ,而 组 内 采取 全 相 联 映像 。 

当 组 相 联 映像 中 组 内 的 块 容 量 为 1 时 ,就 转化 为 直接 映像 ; 当 组 内 的 块 容 量 为 Cache 的 
容量 时 ,就 转化 为 全 相 联 映 像 。 因 此 ,组 相 联 映像 实际 上 是 全 相 联 映像 和 直接 映像 的 折 中 方 
案 , 其 优点 和 缺点 介 于 全 相 联 和 直接 映像 方式 的 优 缺 点 之 间 。 

组 相 联 映像 规则 如 图 5-29(c) 所 示 。Cache 分 为 4 组 ,每 组 2 块 。 主 存 的 第 9 块 将 可 以 
映像 到 Cache 第 1 组 的 位 置 上 。 组 相 联 映像 的 关系 可 以 定义 为 : 

.J =I modQ 
式 中 ,J 为 Cache 的 组 号 ;I 为 主 存 的 块 号 ;Q 为 Cache 的 组 数 。 


5.7.4 替换 算法 


在 采用 全 相 联 映像 和 组 相 联 映像 方式 从 主 存 问 Cache 传送 一 个 新 块 ,而 Cache 中 的 空 
间 已 被 占 满 时 ,就 需要 把 原来 存储 的 一 块 蔡 换 掉 。 和 常用 的 蔡 换 算法 有 下 述 3 种。 


1. 随机 算法 


最 简单 的 蔡 换 算法 是 随机 方法 。 随 机 法 完全 不 管 Cache 块 过 去 、 现 在 及 将 来 的 使 用 情 
况 , 人 简单 地 根据 一 个 随机 数 ,选择 一 块 蔡 换 摊 。 


2. 先进 先 出 (FIFO) 算 法 


FIFO 算法 的 思想 是 : 按 调 入 Cache 的 先后 决定 淘汰 的 顺序 , 即 在 需要 更 新 时 ,将 最 先 
进入 Cache 的 块 作为 被 蔡 换 的 块 。 这 种 方法 要 求 为 每 块 做 一 记录 , 记 下 它们 进入 Cache 的 
先后 次 序 。 这 种 方法 容易 实现 ,而 且 系 统 开销 小 。 其 缺点 是 可 能 会 把 一 些 需 要 经 常 使 用 的 
程序 块 (如 循环 程序 ) 也 作为 最 早 进入 Cache 的 块 蔡 换 掉 。 


3. 近期 最 少 使 用 (LRU) 算 法 


LRU 算法 是 把 CPU 近期 最 少 使 用 的 块 作为 被 蔡 换 的 块 。 这 种 蔡 换 方法 需要 随时 记录 
Cache 中 各 块 的 使 用 情况 ,以 便 确定 哪个 块 是 近期 最 少 使 用 的 块 。LRU 算法 相对 合理 ,但 
实现 起 来 比较 复杂 ,系统 开销 较 大 。 通 常 需要 对 每 一 块 设置 一 个 称 为 “年 龄 计数 器 ”的 硬件 
或 软件 计数 器 ,用 于 记录 其 被 使 用 的 情况 。 


5S.7.5 更 新 策略 


为 了 解决 Cache 与 主 存 中 内 容 不 一 致 问题 ,首先 要 选择 合适 的 Cache 更 新 策略 。Cache 
有 两 种 更 新 策略 : 写 直 达 法 和 写 回 法 。 
写 直 达 法 是 指 CPU 在 执行 写 操作 时 ,必须 把 数据 同时 写 入 Cache 和 主 存 。 当 某 一 块 需 
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要 符 换 时 ,也 不 必 把 这 一 块 与 回 到 主 存 中 ,新 调和 人 的 块 可 以 立即 把 这 一 块 覆 盖 。 这 种 方法 实 
现 简单 ,而 且 能 随时 保持 主 存 数 据 的 正确 性 ,但 可 能 增加 多 次 不 必要 的 主 存 写 入 ,会 降低 存 
取 速 度 。 

写 回 法 是 指 CPU 在 执行 写 操作 时 ,被 写 数据 只 写 入 Cache, 不 写 人 主 存 。 仅 当 需 要 替 
换 时 , 才 把 已 经 修改 过 的 Cache 块 写 回 到 主 存 。 在 采用 这 种 更 新 策略 的 Cache 块 表 中 ,一 般 
有 一 个 标志 位 ( 称 为 * 脏 ”位 ), 当 一 块 中 的 任何 一 个 单元 被 修改 时 ,标志 位 被 置 “1”。 在 需要 
蔡 换 掉 这 一 块 时 ,如 果 标 志 位 为 “1”( 表 示 该 块 数据 已 经 脏 ” 了 ), 则 必须 先 把 这 一 块 写 回 到 
主 存 中 之 后 ,才能 再 调 入 新 的 块 ;如 果 标 志 位 为 “0”( 表 示 该 块 数据 还 是 干净 的 ), 则 这 一 块 不 
必 写 回 主 存 , 只 要 用 新 调 入 的 块 覆盖 掉 这 一 块 即 可 。 这 种 方法 操作 速度 快 ,但 因 主 存 中 的 字 
块 未 及 时 修改 而 有 可 能 出 错 。 


S.7.6 微机 中 Cache 技术 的 实现 


Cache 刚 出 现时 ,典型 系统 中 只 有 一 个 Cache, 而 近年 来 的 微机 系统 中 普遍 采用 了 多 个 
Cache。 多 个 Cache 的 含义 有 两 方面 : 一 是 增加 Cache 的 级 数 ; 二 是 将 统一 的 Cache 变 成 分 
开 的 Cache。 下 面 以 PC 为 例 介 绍 Cache 技术 的 实现 。 


1. 单一 缓存 和 多 级 缓存 


所 谓 单一 缓存 ,顾名思义 是 在 CPU 和 主 存 之 间 只 设 一 个 Cache。80386 以 前 的 CPU 只 
有 外 部 的 Cache。 

随 着 集成 电路 技术 的 发 展 ,Cache 被 直接 与 CPU 制作 在 同一 个 芯片 内 , 称 为 一 级 Cache 
(L1 Cache) ,又 称 片 内 Cache。L1 Cache 总 是 以 CPU 的 核心 速度 运行 ,是 所 有 系统 中 最 快 
的 高 速 缓存 。CPU 直接 访问 Ll Cache, 不 必 占 用 外 部 总 线 ,而 且 L1 Cache 与 CPU 之 间 的 
数据 通路 很 短 , 所 以 大 大 提高 了 存 取 速度 ,但 L1 Cache 容量 较 小 ,一 般 仅 为 几 十 KB。 而 此 
时 安装 在 主板 上 的 Cache 则 称 为 L2 Cache( 二 级 缓存 ),L2 Cache 以 主板 速度 运行 ,可 以 有 
较 大 的 容量 ,从 256KB 到 2MB 不 等 。 从 Pentium Pro 和 Pentium [I 微 处 理 器 开始 ,将 L2 
Cache 和 CPU 封装 在 一 起 ,最 初速 度 为 CPU 核心 速度 的 一 半 、 五 分 之 二 或 三 分 之 一 。 后 
来 ,大 多 数 CPU 芯片 内 都 同时 集成 了 Ll 和 L2 Cache ,并 都 能 以 全 核心 速度 运行 ,被 称 为 片 
内 两 级 Cache 设计 。 之 后 ,为 谈 取 L2 Cache 后 未 命中 的 数据 又 设计 了 L3 Cache, 在 拥有 三 
级 缓存 的 CPU 中 ,只 有 约 5% 的 数据 需要 从 内 存 中 调用 ,这 进一步 提高 了 CPU 的 效率 ,一 
开始 L3 Cache 是 外 置 的 ,到 2012 年 以 后 都 是 内 置 的 ,即将 L3 Cache 也 封 波 在 处 理 颖 盒 内 。 
目前 ,主流 CPU 的 L2 Cache 一 般 为 512KB 到 6MB 不 等 ,L3 Cache 一 般 为 3MB 到 24MB 
不 等 。 

多 级 Cache 的 技术 难度 和 制造 成 本 是 相对 递减 的 ,所 以 其 容量 也 是 相对 递增 的 。CPU 
访 存 时 首先 查找 L1 Cache, 如果 L1 Cache 不 命中 , 则 访问 L2 Cache…… 直到 所 有 级 别 的 
Cache 都 不 命中 时 , 才 访 问 主 存 。 假 设 , 在 拥有 两 级 Cache 的 CPU 中 , 读 取 Ll Cache 的 命 
中 率 为 80%, 读 取 L2 的 命中 率 也 在 80%( 从 L2 读 到 有 用 的 数据 占 总 数据 的 16% ) , 剩 下 的 
数据 就 不 得 不 从 主 存 中 调用 了 ,但 这 只 占 总 数据 的 4%。 


和 郑 和 刍 系统 和 结构 


2. 统一 缓存 和 分 开 缓 存 


统一 缓存 是 指 指令 和 数据 都 存放 在 同一 个 Cache 中 。 而 分 开 缓 存 是 指 指令 和 数据 分 别 
存放 在 两 个 Cache 中 ,一 个 称 为 指令 Cache, 男 一 个 称 为 数据 Cache。 

80486 及 其 以 前 的 微 处 理 带 都 只 有 统一 缓存 ,由 于 Pentium 开始 采用 流水 线 控制 技术 ， 
所 以 必须 将 指令 和 数据 的 Cache 分 开 , 以 满足 指令 预 取 和 指令 执行 并 行 的 需要 ,否则 将 可 能 
出 现 取 指 和 执行 过 程 对 统一 缓存 的 争 用 。 目 前 , 绝 大 多 数 CPU 中 的 Ll1 Cache 都 将 指令 
Cache 和 数据 Cache 分 开 , 成 为 典型 的 哈佛 结构 。 一 般 情 况 下 ,Ll 数据 Cache 和 L1 指令 
Cache 的 容量 相同 ,二 者 分 别 用 来 存放 数据 和 指令 ,并 对 执行 这 些 数据 的 指令 进行 即时 解 
码 。 例 如 ,AMD 的 Athlon XP 就 具有 64KB 的 L1 数据 Cache 和 64KB 的 L1 指令 Cache， 
其 L1 Cache 就 以 64KB 十 64KB 来 表示 。 但 Pentium 4 的 L1 Cache 有 点 特殊 , 它 使 用 新 增 
加 的 一 种 一 级 追踪 缓存 (上 Execution Trace Cache,ETC) 来 蔡 代 指令 Cache, 容 量 为 12KyOps 
(表示 能 存储 12K 条 微 指 令 , 有 关 微 指令 的 概念 将 在 第 6 曹 中 详细 讨论 ) ,而 其 数据 Cache 
只 有 8KB, 故 其 一 级 缓存 就 以 8KB 十 12KyOps 表示 。 

一 级 退 踊 缓存 与 一 级 指令 缓存 的 运行 机 制 是 不 相同 的 ,一 级 奶 中 缓存 能 将 微 指 令 储 存 
在 一 级 追 踩 缓存 之 内 ,所 以 有 效 地 增加 了 高 工作 频率 下 对 指令 的 解码 能 力 。 

注意 : 在 这 里 12KyOps 绝对 不 等 于 12KB, 二 者 单位 不 同 , 运 行 机 制 不 同 , 简 单 相 加 得 
出 L1 Cache 容量 的 看 法 是 完全 错误 的 。 

除去 L1 Cache 以 外 ,L2 Cache 和 L3 Cache 都 只 存储 数据 。 


5.8 虚拟 存储 顷 


虚拟 存储 器 由 主 存储 器 和 联机 工作 的 辅助 存储 器 (通常 为 磁盘 存储 器 ) 共 同 组 成 ,这 两 
个 存储 器 在 硬件 和 系统 软件 的 共同 管理 下 工作 ,对 于 应 用 程序 员 , 可 以 把 它们 看 作 一 个 单一 
的 存储 需 。 


S.8.1 虚拟 存储 器 的 基本 概念 


虚拟 存储 器 将 主 存 或 辅 存 的 地 址 空间 统一 编 址 ,形成 一 个 庞大 的 存储 空间 。 在 这 个 大 
空间 里 ,用 户 可 以 自由 编程 ,完全 不 必 考 虑 程序 在 主 存 是 否 装 得 下 以 及 这 些 程序 将 来 在 主 存 
中 的 实际 存放 位 置 。 

用 户 编 程 的 地 址 称 为 虚 地 址 或 逻辑 地 址 ,实际 的 主 存单 元 地 址 称 为 实地 址 或 物理 地 址 。 
显然 , 虚 地 址 要 比 实 地 址 大 得 多 。 

在 实际 的 物理 存储 层次 上 ,所 编程 序 和 数据 在 操作 系统 管理 下 , 先 送 入 磁盘 ,然后 操作 
系统 将 当前 运行 所 需要 的 部 分 调 人 主 存 , 供 CPU 使 用 ,其 余 暂 不 运行 部 分 留 在 磁盘 中 。 

程序 运行 时 ,CPU 以 虚 地 址 来 访问 主 存 ,由 辅助 硬件 找 出 虚 地 址 和 实地 址 之 间 的 对 应 
关系 ,并 判断 这 个 虚 地 址 指示 的 存储 单元 内 容 是 否 已 装 和 主 存 。 如 果 已 在 主 存 中 , 则 通过 地 
址 变换 ,CPU 可 直接 访问 主 存 的 实际 单元 ;如 果 不 在 主 存 中 , 则 把 包含 这 个 字 的 一 页 或 一 个 
程序 段 调 入 主 存 后 再 由 CPU 访问 。 如 果 主 存 已 满 , 则 由 替换 算法 从 主 存 中 将 暂 不 运行 的 
一 页 或 一 段 调 回 辅 存 ,再 从 辅 存 调 入 新 的 一 页 或 一 段 到 主 存 。 从 原理 的 角度 看 ,虚拟 存储 器 


二 
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和 Cache- 主 存 有 不 少 相 同 之 处 。 事 实 上 ,前 面 提 到 的 各 种 方法 是 先 应 用 于 虚拟 存储 硕 中 ， 
后 来 才 发 展 到 Cache- 主 存 层 次 中 的 。 


5.8.2 页 式 虚拟 存储 器 


以 页 为 基本 单位 的 虚拟 存储 器 称 为 页 式 虚拟 存储 器 。 各 类 计算 机 页 面 大 小 不 等 ,一 般 
为 512B 到 几 KB。 主 存 空间 和 虚 存 空间 都 划分 成 奋 干 个 大 小 相等 的 页 。 主 存 即 实 存 的 页 
称 为 实 页 , 虚 存 的 页 称 为 虚 页 。 

程序 虚 地 址 分 为 两 个 字段 : 高 位 字段 为 虚 页 号 ,低位 字段 为 页 内 地 址 。 虚 地 址 到 实地 
址 之 间 的 变换 是 由 页 表 来 实现 的 。 页 表 是 一 张 存 放 在 主 存 中 的 虚 页 号 和 实 页 号 的 对 照 表 ， 
记录 着 程序 的 虚 页 调 入 主 存 时 被 安排 在 主 存 中 的 位 置 。 夺 计算 机 采用 多 道 程序 工作 方式 ， 
则 可 为 每 个 用 户 作 业 建 立 一 个 页 表 ,硬件 中 设置 一 个 页 表 基 址 寄存 器 ,存放 当前 所 运行 程序 
的 页 表 的 起 始 地 址 。 

页 表 中 的 每 一 行 记录 了 与 某 个 虚 页 对 应 的 奋 干 信息 ,包括 虚 页 号 、 装 人 位 和 实 页 号 等 。 
页 表 基 址 寄存 需 和 虚 页 号 拼接 成 页 表 索 引 地 址 。 根 据 这 个 索引 地 址 可 读 到 一 个 页 表 信 息 
字 , 然 后 检测 页 表 信 息 字 中 装 和 位 的 状态 。 奋 装 和 位 为 "1”, 则 表示 该 页 面 已 在 主 存 中 ,将 对 
应 的 实 页 号 与 虚 地 址 中 的 页 内 地 址 相 拼接 就 得 到 了 完整 的 实地 址 ; 知 装 入 位 为 "0”, 则 表示 
该 页 面 不 在 主 存 中 ,于 是 要 启动 1/O 系统 ,把 该 页 从 辅 存 中 调和 人 主 存 后 再 供 CPU 使 用 。 
图 5-30 给 出 了 页 式 虚 拟 存储 需 的 虚 - 实 地 址 的 变换 过 程 。 


页 表 基 址 寄存 器 
页 表 起 始 地 址 页 内 地 址 | 虚 地 址 


图 5-30 页 式 虚 拟 存储 器 的 虚 - 实 地 址 变换 


从 上 述 地 址 转换 过 程 可 知 ,CPU 访 存 时 首先 要 查 页 表 , 为 此 需要 访问 一 次 主 存 , 夺 不 命 
中 ,还 要 进行 页 面 蔡 换 和 页 表 修 改 , 则 访问 主 存 的 次 数 就 更 多 了 。 

页 式 虚 拟 存储 希 的 每 页 长 度 是 固定 的 ,页 表 的 建立 很 方便 ,新 页 的 调和 人 也 容易 实现 。 但 
是 ,由 于 程序 不 可 能 正好 是 页 面 的 整 倍 数 ,最 后 一 页 的 零头 将 无 法 利用 而 造成 浪费 。 同 时 ， 
页 不 是 逻辑 上 独立 的 实体 ,使 得 程序 的 处 理 \ 保 护 和 共享 都 比较 麻烦 。 


5.8.3 段 式 虚拟 存储 器 


段 式 虚拟 存储 融 中 的 段 是 按照 程序 的 逻辑 结构 划分 的 ,各 个 段 的 长 度 因 程序 而 异 。 为 
了 把 程序 虚 地 址 变换 成 主 存 实地 址 ,需要 一 个 段 表 。 段 表 中 每 一 行 记 录 了 茶 个 段 对 应 的 寿 
干 信息 ,包括 段 号 `. 装 人 位 、 段 起 点 和 段 长 等 。 段 表 一 般 驻 留 在 主 存 中 。 奋 装 入 位 为 "1”, 则 
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表示 该 段 已 调 入 主 存 : 若 装 和 人 位 为 "0”, 则 表示 该 段 不 在 主 ”程序 空间 长度 主 存 实 空间 地 址 
存 中 。 由 于 段 的 大 小 可 变 , 所 以 在 段 表 中 要 给 出 各 段 的 起 IK 
始 地 址 与 段 的 长 度 。 段 表 实 际 上 是 程序 的 逻辑 结构 段 与 
其 在 主 存 中 所 存放 的 位 置 之 间 的 关系 对 照 表 ,如 图 5-31 NM 
所 示 。 | 
编程 使 用 的 虚 地 址 包含 两 部 分 : 段 号 和 上段 内 地 址 。 段 
式 虚 拟 存 储 需 的 虚 - 实 地 址 的 变换 过 程 如 图 5-32 所 示 。 
CPU 根据 虚 地 址 访 存 时 ,首先 将 段 号 与 段 表 的 起 始 地 址 相 
拼接 ,形成 访问 段 表 对 应 行 的 地 址 ,然后 根据 段 表 内 装 入 
位 判断 该 段 是 否 已 调和 人 主 存 。 若 已 调 入 主 存 , 从 段 表 读 出 
该 段 在 主 存 中 的 起 始 地 址 ,与 段 内 地 址 ( 偏 移 量 ) 相 加 ,得 
到 对 应 的 主 存 实 地 址 。 
由 于 段 的 分 界 与 程序 的 自然 分 界 相 对 应 ,所 以 具有 逻 ”图 5-31 程序 在 主 存 中 的 分 配 
辑 独立 性 ,易于 程序 的 编译 、 管 理 . 修改 和 保护 ,也 便于 多 及 其 段 表 
道 程序 共享 。 但 是 ,因为 段 的 长 度 参差 不 齐 , 起 点 和 终点 
不 定 , 给 主 存 空间 分 配 带 来 了 友 烦 ;容易 在 段 间 留 下 不 能 利用 的 零头 ,造成 浪费 。 


自 表 基 址 寄存 器 
段 内 地 址 | 虚 地 址 
一 自 表 
自 表 地 址 
| 一 © 


5-32 上 段 式 虚拟 存储 器 的 虚 - 实 地 址 变换 


5.8.4 段 页 式 虚 拟 存 储 器 


在 段 式 、 页 式 存 储 硕 的 基础 上 ,还 有 一 种 段 页 式 虚拟 存储 天。 将 程序 按 其 逻辑 结构 分 
段 ,每 段 再 划分 为 奋 干 大 小 相等 的 页 ; 主 存 空间 也 划分 为 右 干 同样 大 小 的 页 。 虚 存 和 实 存 之 
间 以 页 为 基本 传送 单位 ,每 个 程序 对 应 一 个 段 表 ,每 段 对 应 一 个 页 表 。CPU 访问 时 , 虚 地 址 
包含 段 号 、 段 内 页 号 、 页 内 地 址 3 部 分 。 首 先 将 段 表 起 始 地 址 与 段 号 合成 ,得 到 段 表 地 址 ; 然 
后 从 段 表 中 取出 该 段 的 页 表 起 始 地 址 ,与 段 内 页 号 合成 ,得 到 页 表 地 址 ;最 后 从 页 表 中 取出 
实 页 号 ,与 页 内 地 址 拼接 形成 主 存 实 地 址 。 段 页 式 存 储 融 综合 了 前 两 种 结构 的 优点 ,但 要 经 
过 两 级 查 表 才 能 完成 地 址 转换 ,费时 要 多 些 。 

段 页 式 虚 拟 存储 如 将 存储 空间 按 人 逻辑 模块 分 成 段 ,每 段 又 分 成 大 干 个 页 , 访 存 通过 一 个 
段 表 和 奋 干 个 页 表 进 行 。 段 的 长 度 必须 是 页 长 的 整数 倍 , 段 的 起 点 必须 是 茶 一 页 的 起 点 。 
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5.8.5 快 表 与 慢 表 


在 虚拟 存储 器 中 ,如果 不 采取 有 效 的 措施 ,访问 主 存 的 速度 将 要 降低 几 倍 ,这 是 因为 在 
页 式 或 段 式 虚拟 存储 器 中 ,必须 先 查 页 表 或 段 表 ;在 段 页 式 虚拟 存储 器 中 , 既 要 查 段 表 也 要 
查 页 表 。 

要 想 使 访问 虚 存 的 速度 接近 于 访问 主 存 的 速度 ,必须 加 快 查 表 的 速度 。 由 于 程序 在 执 
行 过 程 中 具有 局 部 性 的 特点 ,因此 对 页 表 的 访问 并 不 完全 是 随机 的 。 在 一 段 时间 内 ,对 页 表 
的 访问 只 是 局 限 在 少数 几 个 存储 器 宇内。 为 了 将 访问 页 表 的 时 间 降 低 到 最 低 限 度 , 许 多 计 
算 机 将 页 表 分 为 快 表 和 慢 表 两 种 。 将 当前 最 常用 的 页 表 信 息 存放 在 一 个 小 容量 的 高 速 存储 
器 中 , 称 为 “ 快 表 ”(TLB), 当 快 表 中 查 不 到 时 , 青 从 存放 在 主 存 中 的 页 表 中 查找 实 页 号 。 与 
快 表 相对 应 ,存放 在 主 存 中 的 页 表 称 为 “ 慢 表 ”。 快 表 只 是 慢 表 的 一 个 副本 ,而 且 只 存放 了 慢 
表 中 很 少 的 一 部 分 。 

实际 上 , 快 表 与 慢 表 也 构成 了 一 个 由 两 级 存储 器 组 成 的 存储 系统 ,其 访问 速度 接近 于 快 
表 的 速度 ,存储 容量 是 慢 表 的 容量 。 快 表 容 量 很 小 ( 几 十 个 字 ) ,速度 高 ,采用 相 联 方式 , 按 内 
容 访问 。 


习 题 


5-1 如 何 区 别 存储 器 和 寄存 器 ? 两 者 是 一 回 事 的 说 法 对 吗 ? 

5-2 存储 器 的 主要 功能 是 什么 ? 为 什么 要 把 存储 系统 分 成 各 干 个 不 同 层次 ? 主要 有 哪些 层次 ? 

5-3 在 一 个 字 节 编 址 的 计算 机 中 ,假定 int 型 变量 i 的 地 址 为 0200H,i 的 机 器 数 为 01234567H ,请 用 
表格 的 方式 分 别 列 出 大 端 方案 和 小 端 方案 情况 下 各 个 字 节 对 应 的 主 存 地 址 。 

5-4 某 机 存储 字 长 64 位 , 主 存储 器 按 字 节 编 址 , 现 有 4 种 不 同 长 度 的 数据 : 字 节 、 半 字 (16 位 ) .单字 
(32 位 ) 、 双 字 (64 位 ) ,请 采用 一 种 既 节省 存储 空间 ,又 能 保证 任 一 个 数据 都 在 单个 存 取 周 期 中 完成 读 写 的 
方法 ,将 不 同 长 度 的 数据 存 人 主 存 (采用 大 端 方案 ) 。 

(1) 写 出 不 同 长 度数 据 存放 在 主 存 中 地 址 的 限定 要 求 ( 即 第 一 个 字 节 的 地 址 ) 。 

(2) 画 出 将 字 节 、 双 字 、 半 字 、 单 字 、 字 节 5 个 数据 依次 存放 在 主 存 中 的 示意 图 (不 能 改变 顺序 ) 。 

5-5 动态 RAM 为 什么 要 刷新 ? 一 般 有 几 种 刷新 方式 ? 各 有 什么 优 缺 点 ? 

5-6 ”一般 存储 芯片 都 设 有 片 选 端 CS, 它 有 什么 用 途 ? 

5-7 DRAM 芯片 和 SRAM 芯片 通常 有 何不 同 ? 

5-8 ”有 哪 几 种 只 读 存储 器 ? 它们 各 自 有 何 特点 ? 

5-9 说 明 存 取 周 期 和 存 取 时 间 的 区 别 。 

5-10 一 个 1KX8 的 存储 芯片 需要 多 少 根 地 址 线 .数据 输入 线 和 输出 线 ? 

5-11 某 计 算 机 字 长 为 32 位 ,其 存储 容量 是 64KB, 按 字 编 址 的 寻 址 范围 是 多 少 ? 若 主 存 以 字 节 编 址 ， 
试 画 出 主 存 字 地 址 和 字 节 地 址 的 分 配 情况 。 

5-12 一 个 容量 为 16K X 32 的 存储 器 ,其 地 址 线 和 数据 线 的 总 和 是 多 少 ? 当选 用 下 列 不 同 规格 的 存 
储 芯 片 时 ,各 需要 多 少 片 ? 

1KX4,2KX8,4KX4,16KX1,4KX8,8KX8 

5-13 ” 现 有 1024X1 的 存储 芯片 , 若 用 它 组 成 容量 为 16KX8 的 存储 器 。 试 求 : 

(1) 实现 该 存储 器 所 需 的 芯片 数量 。 

(2) 若 将 这 些 芯 片 分 装 在 若干 块 板 上 ,每 块 板 的 容量 为 4KX8, 该 存储 器 所 需 的 地 址 线 总 位 数 是 多 少 ? 


疗 储 系统 和 结 艾 


其 中 几 位 用 于 选 板 ? 几 位 用 于 选 片 ? 几 位 用 作 片 内 地 址 ? 

5-14 已 知 某 计 算 机 字 长 8 位 , 现 采 用 半导体 存储 器 作 主 存 , 其 地 址 线 为 16 位 , 铬 使 用 1KX4 的 
SRAM 芯片 组 成 该 机 所 人 允许 的 最 大 主 存 空间 ,并 采用 存储 模板 结构 形式 。 

(1) 车 每 块 模板 容量 为 4KX8, 共 需 多 少 块 存储 模板 ? 

(2) 画 出 一 个 模板 内 各 芯片 的 连接 逻辑 图 。 

5-15“ 某 半 导体 存储 器 容量 16KX8, 可 选 SRAM 芯片 的 容量 为 4KX4; 地 址 总 线 A; 一 Au (A, 为 最 低 
位 ) ,双向 数据 总 线 D; 一 Du(D, 为 最 低位 ) ,由 R/W 线 控制 读 写 。 设 计 并 画 出 该 存储 器 的 逻辑 图 ,并 注 明 地 
址 分 配 、 片 选 逻 辑 及 片 选 信 号 的 极 性 。 

5-16 现 有 如 下 存储 芯片 : 2KX1 的 ROM、4KX1 的 RAM.8KX1 的 ROM。 若 用 它们 组 成 容量 为 
16KB 的 存储 器 ,前 4KB 为 ROM, 后 12KB 为 RAM,CPU 的 地 址 总 线 16 位 。 

(1) 各 种 存储 芯片 分 别 用 多 少 片 ? 

(2) 正确 选用 译 码 器 及 门 电路 ,并 画 出 相应 的 逻辑 结构 图 。 

(3) 指出 有 无 地 址 重 秋 现象 。 

5-17 用 容量 为 16KX1 的 DRAM 芯片 构成 64KB 的 存储 器 。 

(1) 画 出 该 存储 器 的 结构 框图 。 

(2) 设 存储 器 的 读 写 周期 均 为 0. 5ps,CPU 在 lps 内 至 少 要 访 存 一 次 ,试问 采用 哪 种 刷新 方式 比较 合 
理 ? 相 邻 两 行 之 间 的 刷新 间隔 是 多 少 ? 对 全 部 存储 单元 刷新 一 遍 所 需 的 实际 刷新 时 间 是 多 少 ? 

5-18 有 一 个 8 位 机 ,采用 单 总 线 结构 ,地 址 总 线 16 位 (A; 一 Au ) ,数据 总 线 8 位 (D; 一 D, ) ,控制 总 线 
中 与 主 存 有 关 的 信号 有 MREQ( 低 电 平 有 效 允 许 访 存 ) 和 R/W( 高 电 平 为 读 命令 , 低 电 平 为 写 命令 )。 

主 存 地 址 分 配 如 下 : 从 0 一 8191 为 系统 程序 区 ,由 ROM 芯片 组 成 ;从 8192 一 32767 为 用 户 程序 区 ;最 
后 (最 大 地 址 )2K 地 址 空间 为 系统 程序 工作 区 (上 述 地 址 均 用 十 进 制 表示 , 按 字 节 编 址 ) 。 

现 有 如 下 存储 芯片 : 8KX8 的 ROM,16KX1、2KX8、4KX8、8KX8 的 SRAM。 从 上 述 规格 中 选用 芯 
片 设计 该 机 主 存储 器 , 画 出 主 存 的 连接 框图 ,并 注意 画 出 片 选 逻 辑 及 与 CPU 的 连接 。 

5-19 某 半导体 存储 器 容量 为 15KB, 其 中 固化 区 为 8SKB, 可 选 EPROM 芯片 为 4KX8; 可 随机 读 写 区 
为 7KB, 可 选 SRAM 芯片 有 : 4KX4、2KX4、1KX4。 地址 总 线 As 一 Au (Au 为 最 低位 ), 双 向 数据 总 线 
D; 一 Du (D, 为 最 低位 ),R/W 为 控制 读 写 , MREQ 为 低 电 平时 允许 存储 器 工作 信号 。 设 计 并 画 出 该 存储 器 
逻辑 图 , 注 明 地 址 分 配 、 片 选 逻辑 、 片 选 信号 极 性 等 。 

5-20 ” 某 计 算 机 地 址 总 线 16 位 As 一 Au(A, 为 最 低位 ) , 访 存 空间 64KB。 外 围 设备 与 主 存 统一 编 址 ， 
I/O 空 间 占 用 FC00~~FFFFH。 现 用 2164 芯片 (64KX1) 构 成 主 存 储 器 ,设计 并 画 出 该 存储 器 逻辑 图 ,并 夯 
出 芯片 地 址 线 ,数据 线 与 总 线 的 连接 逻辑 以 及 行 选 信 号 与 列 选 信 号 的 逻辑 式 , 使 访问 I/O 时 不 访问 主 存 。 
动态 刷新 逻辑 可 以 暂 不 考虑 。 

5-21 已 知 有 16KX1 的 DRAM 芯片 ,其 引 脚 功 能 如 下 : 地 址 输入 As 一 Au , 行 地 址 选择 RAS, 列 地 址 
选择 CAS ,数据 输入 端 Di ,数据 输出 端 D。 ,控制 端 WE。 请 用 给 定 芯 片 构成 256KB 的 存储 器 ,采用 奇偶 校 
验 ,试问 : 需要 芯片 的 总 数 是 多 少 ? 并 完成 下 列 问 题 。 

(1) 正确 画 出 存储 器 的 连接 框图 。 

(2) 写 出 各 芯片 RAS 和 CAS 形 成 条 件 。 

(3) 若 芯片 内 部 采用 128X128 和 矩阵 排列 , 求 异 步 刷 新 时 该 存储 器 的 刷新 周期 。 

5-22 ”并行 存储 器 有 了 哪 几 种 编 址 方式 ? 简 述 低位 交叉 编 址 存储 器 的 工作 原理 。 

5-23 ”什么 是 高 速 缓冲 存储 器 ? 它 与 主 存 是 什么 关系 ? 其 基本 工作 过 程 如 何 ? 

5-24 ”Cache 做 在 CPU 芯片 内 有 什么 好 处 ?将 指令 Cache 和 数据 Cache 分 开 又 有 什么 好 处 ? 

5-25” 设 某 计 算 机 主 存 容量 为 4MB,Cache 容量 为 16KB, 每 块 包含 8 个 字 ,每 字 32 位 ,设计 一 个 4 路 
组 相 联 映像 ( 即 Cache 每 组 内 共有 4 个 块 ) 的 Cache 组 织 ,要 求 : 
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(1) 画 出 主 存 地 址 字段 中 各 段 的 位 数 。 

(2) 设 Cache 的 初 态 为 空 ,CPU 依次 从 主 存 第 0,1,2,…,99 号 单元 读 出 100 个 字 ( 主 存 一 次 读 出 一 个 
字 ) ,并 重复 按 此 次 序 读 8 次 , 问 命 中 率 是 多 少 ? 

(3) 大 Cache 的 速度 是 主 存 的 6 倍 ,试问 有 Cache 和 无 Cache 相 比 ,速度 提高 多 少 倍 ? 

5-26 ”什么 叫 虚拟 存储 器 ? 采用 虚拟 存储 技术 能 解决 什么 问题 ? 

5-27 已 知 采用 页 式 虚 拟 存储 器 , 某 程序 中 一 条 指令 的 虚 地 址 是 : 000001111111100000。 该 程序 的 页 
表 起 始 地 址 是 0011 ,页 面 大 小 为 1K ,页 表 中 有 关 单 元 最 末 4 位 ( 实 页 号 ) 如 表 5-9 所 示 。 


表 5-9 页 表 
007H 0001 
300H 0011 
307H 1100 


指出 指令 地 址 ( 虚 地 址 ) 变 换 后 的 主 存 实地 址 。 


第 草 
6 中 央 处 理 器 


中 央 处 理 需 (CCPU) 是 整个 计算 机 的 核心 , 它 包 括 运算 需 和 控制 部 。 本 章 着 重 讨论 CPU 
的 功能 和 组 成 ,控制 器 的 工作 原理 和 实现 方法 , 微 程 序 控制 原理 ,基本 控制 单元 的 设计 ,以 及 
先进 的 CPU 系统 设计 技术 。 


6.1 中 央 处 理 器 的 功能 和 组 成 


CPU 对 整个 计算 机 系统 的 运行 是 极其 重要 的 ,这 里 将 从 CPU 的 功能 、 内 部 结构 和 主要 
技术 参数 人 手 , 为 后 面 详细 讨论 程序 的 执行 过 程 打 下 基础 。 


0.1.1 CPU 的 功能 


若 用 计算 机 来 解决 某 个 问题 ,首先 要 为 这 个 问题 编制 解 题 程序 ,而 程序 又 是 指令 的 有 序 
集合 。 按 “存储 程序 ”的 概念 ,只 要 把 程序 装 入 主 存储 器 后 , 即 可 由 计算 机 自动 地 完成 取 指 令 
和 执行 指令 的 任务 。 在 程序 运行 过 程 中 ,在 计算 机 的 各 部 件 之 间 流 动 的 指令 和 数据 形成 了 
指令 流 和 数据 流 。 

注意 : 这 里 的 指令 流 和 数据 流 都 是 程序 运行 的 动态 概念 , 它 不 同 于 程序 中 静态 的 指令 
序列 ,也 不 同 于 存储 器 中 数据 的 静态 分 配 序列 。 指 令 流 指 的 是 CPU 执行 的 指令 序列 ,数据 
流 指 的 是 根据 指令 操作 要 求 依次 存 取 数 据 的 序列 。 从 程序 运行 的 角度 来 看 ,CPU 的 基本 功 
能 就 是 对 指令 流 和 数据 流 在 时 间 与 空间 上 实施 正确 的 控制 。 

对 于 汉 。 诺 依 曼 结构 的 计算 机 而 言 ,数据 流 是 根据 指令 流 的 操作 而 形成 的 ,也 就 是 说 数 
据 流 是 由 指令 流 来 驱动 的 。 


6.1.2 CPU 中 的 主要 奇 存 器 


CPU 中 的 寄存 硕 是 用 来 暂时 保存 运算 和 控制 过 程 中 的 中 间 结 果 、 最 终结 果 以 及 控制 、 
状态 信息 的 , 它 可 分 为 通用 寄存 硕 和 专用 寄存 需 两 大 类 。 

1. 通用 寄存 器 

通用 寄存 需 可 用 来 存放 原始 数据 和 运算 结果 ,有 的 还 可 以 作为 变 址 寄存 需 、 计 数 需 、 地 


址 指针 等 。 现 代 计 算 机 中 为 了 减少 访问 存储 天 的 次 数 ,提高 运算 速度 ,往往 在 CPU 中 设置 
大 量 的 通用 寄存 右 , 少 则 几 个 ,多 则 几 十 个 ,甚至 上 百 个 。 通 用 寄存 带 可 以 由 程序 编 址 访问 。 
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累加 寄存 器 Acc 也 是 一 个 通用 寄存 需 , 它 用 来 暂时 存放 ALU 运算 的 结果 信息 。 例 如 ， 
在 执行 一 个 加 法 运算 前 , 先 将 一 个 操作 数 暂 时 存放 在 Acc 中 ,再 从 主 存 中 取出 另 一 操作 数 ， 
然后 同 Acc 的 内 容 相 加 ,所 得 的 结果 送 回 Acc 中 。 运 算 央 中 至 少 要 有 一 个 累加 寄存 需 。 


2. 专用 寄存 器 


专用 寄存 需 是 专门 用 来 完成 某 一 种 特殊 功能 的 寄存 需 。CPU 中 至 少 要 有 5 个 专用 的 
寄存 器 : 程序 计数 右 (PC) ,指令 寄存 器 (IR) 存储 需 数 据 寄存 器 (MDR) 存储 需 地 址 寄存 需 
(MAR) 和 程序 状态 字 寄 存 器 (PSWR)。 

(1) 程序 计数 大 

程序 计数 器 又 称 为 指令 计数 器 ,用 来 存放 正在 执行 的 指令 地 址 或 者 接着 要 执行 的 下 一 
条 指令 地 址 。 

对 于 顺序 执行 的 情况 ,程序 计数 需 的 内 容 应 不 断 地 增 量 (加 ”12) ,以 控制 指令 的 顺序 执行 。 
这 种 加 ”12 的 功能 ,有 些 机 需 是 程序 计数 希 本 身 具 有 的 ,也 有 些 机 需 是 侍 助 运算 需 来 实现 的 。 

在 遇 到 需要 改变 程序 执行 顺序 的 情况 时 ,将 转移 的 目标 地 址 送 往 程 序 计 数 希 , 即 可 实现 程 
序 的 转移 。 

(2) 指令 寄存 需 

指令 寄存 器 用 来 存放 从 存储 器 中 取出 的 指令 。 当 指令 从 主 存 取出 存 于 指令 寄存 带 之 
后 ,在 执行 指令 的 过 程 中 ,指令 寄存 器 的 内 容 不 允许 发 生变 化 ,以 保证 实现 指令 的 全 部 功能 。 

(3) 存储 器 数据 寄存 器 

存储 需 数 据 寄存 器 用 来 暂时 存放 由 主 存储 器 读 出 的 一 条 指令 或 一 个 数据 字 ; 反 之 , 当 辕 
主 存 写 人 一 条 指令 或 一 个 数据 字 时 ,也 暂时 将 它们 存放 在 存储 器 数据 寄存 器 中 。 

(4) 存储 器 地 址 寄存 器 

存储 器 地 址 寄存 器 用 来 保存 当前 CPU 所 访问 的 主 存单 元 的 地 址 。 由 于 主 存 和 CPU 
之 间 存 在 着 操作 速度 上 的 差别 ,所 以 必须 使 用 地 址 寄存 器 来 保持 地 址 信息 ,直到 主 存 的 读 写 
操作 完成 为 止 。 

当 CPU 和 主 存 进行 信息 交换 ,无 论 是 CPU 向 主 存 存 取 数据 时 ,还 是 CPU 从 主 存 中 读 
出 指令 时 ,都 要 使 用 存储 器 地 址 寄存 器 和 数据 寄存 器 。 

(5) 程序 状态 字 寄 存 器 

程序 状态 字 寄 存 右 又 称 状 态 标志 寄存 器 ,用 来 存放 程序 状态 字 (PSW)。 程 序 状态 字 的 
各 位 表征 程序 和 机 需 运 行 的 状态 ,是 参与 控制 程序 执行 的 重要 依据 之 一 。 它 主要 包括 两 部 
分 内 容 : 一 是 状态 标志 ,如 进位 标志 (C) 、 结 果 为 零 标 志 (Z) 等 ,大 多 数 指令 的 执行 将 会 影响 
到 这 些 标志 位 ;二 是 控制 标志 ,如 中 断 标志 、 陷 阱 标志 等 。 程 序 状态 字 寄 存 需 的 位 数 往 往 等 
于 机 需 字 长 ,各 类 机 需 的 程序 状态 字 寄 存 需 的 位 数 和 设置 位 置 不 尽 相 同 。 例 如 ,8086 微 处 
理 右 的 程序 状态 字 寄 存 嚣 有 16 位 ,如 图 6-1 所 示 ,一共 包括 9 个 标志 位 ,其 中 6 个 为 状态 标 
志 ,3 个 为 控制 标志 。 
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图 6-1 8086 微 处 理 器 的 状态 字 寄 存 天 


6 个 状态 标志 为 : 

。 进位 标志 位 (CF); 

。 辅助 进位 标志 位 (AF); 

。 淤 出 标志 位 (OF); 

。 去 标志 位 C(ZF); 

e 符号 标志 位 (CSF); 

e。 校 验 标志 位 (PF)。 

3 个 控制 标志 为 : 

e。 方 品 标志 (DF) ,表示 串 操 作 指 令 中 字符 串 操 作 的 方向 

。 中 断 允 许 标志 位 (IF) ,表示 CPU 是 否 能 够 响应 外 部 的 可 屏蔽 中 断 请 求 ; 

。 陷阱 标志 位 (CTF) ,为 了 方便 程序 的 调试 ,使 处 理 器 的 执行 进入 单 步 方式 而 设置 的 控 
制 标志 位 。 


6.1.3 CPU 的 组 成 
CPU 由 运算 关 和 控制 需 两 大 部 分 组 成 ,图 6-2 给 出 了 CPU 的 模型 。 
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6-2 CPU 模型 


在 图 6-2 中 ,ID 表示 指令 译 码 器 ,CU 表示 控制 单元 ,其 作用 将 在 稍 后 介绍 。 
控制 器 的 主要 功能 如 下 : 

GO 从 主 存 中 取出 一 条 指令 ,并 指出 下 一 条 指令 在 主 存 中 的 位 置 。 

G@ 对 指令 进行 译 码 或 测试 ,产生 相应 的 操作 控制 信号 ,以 便 启 动 规定 的 动作 。 
@ 指挥 并 控制 CPU 、 主 存 和 输入 输出 设备 之 间 的 数据 流动 方向 。 

运算 器 的 主要 功能 如 下 : 

@ 执行 所 有 的 算术 运算 。 
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@ 执行 所 有 的 逻辑 运算 ,并 进行 逻辑 测试 。 
6.1.4 CPU 的 主要 技术 参数 


CPU 品质 的 高 低 直 接 决定 了 一 个 计算 机 系统 的 档次 ,而 CPU 的 主要 技术 参数 可 以 反 
映 出 CPU 的 大 致 性 能 。 


1。 字 长 


CPU 的 字 长 是 指 在 单位 时 间 内 同时 处 理 的 二 进 制 数据 的 位 数 。CPU 按照 其 处 理 信息 
的 字 长 可 以 分 为 : 8 位 CPU.、16 位 CPU.、32 位 CPU 以 及 64 位 CPU 等 。 


2. 内 部 工作 频率 


内 部 工作 频率 又 称 内 频 或 主 频 , 它 是 衡量 CPU 速度 的 重要 参数 ,计量 单位 为 MHz( 兆 
南 )、GHz( 吉 赫 )。CPU 的 主 频 表 示 在 CPU 内 数字 脉冲 信号 震荡 的 速度 ,与 CPU 实际 的 运 
算 能 力 存 在 一 定 的 关系 ,但 还 没有 一 个 确定 的 公式 能 够 定量 两 者 的 数值 关系 ,因为 CPU 的 
运算 速度 还 要 看 CPU 的 流水 线 的 各 方面 的 性 能 指标 (缓存 、 指 令 集 、CPU 的 位 数 等 ) ,因此 
主 频 仅 是 CPU 性 能 表现 的 一 个 方面 ,而 不 代表 CPU 的 整体 性 能 。 目 前 ,主流 CPU 的 主 频 
一 般 为 几 GHz。 

内 部 时 钟 频 率 的 倒数 是 时 钟 周 期 ,这 是 CPU 中 最 小 的 时 间 元 素 。 每 个 动作 至 少 需要 
一 个 时 钟 周 期 。 

以 PC 系列 微 处 理 器 为 例 ,最 初 的 8086 和 8088 执行 一 条 指令 平均 需要 12 个 时 钟 周 
期 ;80286 和 80386 的 速度 提高 ,每 条 指令 大 约 要 4. 5 个 时 钟 周 期 ;80486 的 速度 进一步 提 
高 ,每 条 指令 大 约 2 个 时 钟 周 期 ;Pentium 具有 双 指 令 流 水 线 , 使 得 每 个 时 钟 周 期 执行 1 一 2 
条 指令 ;而 Pentium pro、Pentium 卫 /Pentium 焉 每 个 时 钟 周期 可 以 执行 3 条 或 更 多 的 指令 。 


3. 外 部 工作 频率 


CPU 除了 主 频 之 外 ,还 有 另 一 种 工作 频率 , 称 为 外 部 工作 频率 , 它 是 由 主板 为 CPU 提 
供 的 基准 时 钟 频 率 。 

在 早期 ,CPU 的 内 频 就 等 于 外 频 。 例 如 ,80486DX-33 的 内 频 是 33MHz, 它 的 外 频 也 是 
33MHz。 也 就 是 说 ,80486DX-33 以 33MHz 的 速度 在 内 部 进行 运算 ,也 同样 以 33MHz 的 速 
度 与 外 界 沟通 。 目 前 ,CPU 的 内 频 越 来 越 高 , 相 比 之 下 ,其 他 设备 的 速度 还 很 缓慢 ,所 以 现 
在 外 频 跟 内 频 不 再 只 是 一 比 一 的 同步 关系 ,从 而 出 现 了 所 谓 的 内 部 倍 频 技 术 ,导致 了 倍 频 ” 
的 出 现 。 内 频 、 外 频 和 售 频 三 者 之 间 的 关系 是 : 

内 频 二 外 频 X 倍 频 

例如 ,80486DX2-66 的 外 频 是 33MHz, 由 于 内 部 2 倍 频 技 术 的 关系 ,外 频 的 值 会 上 月 动 乘 
上 一 个 因数 2 ,而 成 为 内 频 (66MHz) 。 到 了 Pentium 时 代 , 由 于 CPU 支持 多 种 倍 频 , 因 此 在 
设 定 CPU 的 频率 时 ,不 仅 要 设 定 外 频 , 也 要 指定 倍 频 。 

目前 ,CPU 的 内 频 已 高 达 数 个 GHz, 而 外 频 才 发 展 为 266MHz、400MHz 等 ,与 CPU 的 
差距 很 大 ,目前 最 高 的 倍 频数 甚至 可 达 34。 例 如 , Intel Core i7 主 频 3. 4GHz, 外 频 仅 
100MHz。 理 论 上 倍 频 是 从 1. 5 一 直到 无 限 ,以 0.5 为 一 个 间隔 单位 。 
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4. 前 端 总 线 频 率 


前 端 总 线 (Front Side Bus) 通 常用 FSB 表示 , 它 是 CPU 和 外 界 ( 北 桥 世 片 ) 交 换 数 据 的 
通道 ,主要 连接 主 存 .显卡 等 数据 吞吐 率 高 的 部 件 , 因 此 前 端 总 线 的 数据 传输 能 力 对 计算 机 
整体 性 能 作用 很 大 。 如 果 没 有 足够 快 的 前 端 总 线 , 再 强 的 CPU 也 不 能 明显 提高 计算 机 的 
整体 速度 。 

在 Pentium 4 出 现 之 前 ,前端 总 线 频率 与 外 频 是 相同 的 ,因此 往往 直接 称 前 端 总 线 频率 
为 外 频 。 随 着 计算 机 技术 的 发 展 , 需 要 前 端 总 线 频 率 高 于 外 频 , 采 用 了 QDR(CQuad Date 
Rate) 技 术 或 者 其 他 类 似 的 技术 ,使 得 前 端 总 线 频率 成 为 外 频 的 2 倍 .4 倍 甚至 更 高 。 

FSB 的 频率 采用 “MHz” 作 为 单位 ,PC 上 主流 的 前 端 总 线 频率 有 800MHz、1066MHz、 
1333MHz、1600MHz 几 种 ,前端 总 线 频率 越 高 ,代表 着 CPU 与 内 存 之 间 的 数据 传输 率 
越 高 。 

数据 吾 宽 一 总 线 频率 义 数据 位 宽 二 8 

例如 ,64 位 ,1600MHz 的 FSB 所 提供 的 内 存 珊 宽 是 1600MHzX64b 二 8 王 12 800MB/s 王 
12. 5GB/s。 

虽然 前 端 总 线 频 率 看 起 来 已 经 很 高 ,但 与 同时 不 断 提升 的 内 存 频 率 、 高 性 能 显卡 相 比 ,前 
端 总 线 瓶 颈 仍 未 根本 改变 。 目 前 ,大 多 数 CPU 中 的 FSB 已 被 QPI 总 线 或 DMI 总 线 取 代 ,为 新 
一 代 的 处 理 器 提供 更 快 、 更 高 效 的 数据 带宽 ,FSB 的 系统 瓶颈 问题 也 随 之 得 以 解决 。 


5. QPI 数据 传输 速率 


快速 通道 互联 (Quick Path Interconnect,QPI) 是 一 种 取代 FSB 的 基于 包 传 输 的 高 速 点 
到 点 连接 技术 。 原 来 北桥 芯片 中 的 内 存 控制 需 集 成 到 CPU 内 部 ,让 CPU 通过 PQI 总 线 直 
接 和 内 存 通信 ,不 再 通过 北桥 芯片 组 ,这 很 明显 加 快 了 速度 。 

QPI 抛弃 了 FSB 易 混淆 的 单位 "MHz”, 而 使 用 GT/s” 或 “MT/s”, 明 确 地 表示 总 线 实 
际 的 数据 传输 速率 ,而 不 是 时 钟 频 率 。T/s 即 transfers per second, 表 示 每 秒 数据 传输 的 次 
数 。QPI 总 线 采 用 的 是 2 : 1 比率 , 即 实际 的 数据 传输 速率 两 们 于 实际 的 总 线 时 钟 频率 。 
QPI 的 时 钟 频率 基于 2. 4 GHz、3. 2GHz, 则 QPI 的 数据 传输 速率 为 4. 8GT/s、6. 4GT/s。 
例如 ,时 钟 频率 2. 4GHz 的 QPI 的 数据 传输 速率 是 2.4GHzX2=4.8GT/s。 

一 个 基本 的 QPI 数据 包 是 80 位 ,需要 4 次 传输 完成 整个 数据 包 的 传输 ,每 次 传输 的 20 
位 数据 中 ,有 16 位 为 有 效 数据 ,其 余 4 位 用 于 循环 元 余 校 验 。 由 于 QPI 是 双 回 的 ,在 发 送 
的 同时 也 可 以 接收 另 一 端 传输 来 的 数据 ,这 样 ,每 个 QPI 总 线 总 市 宽 王 每 秒 传输 次 数 ( 即 
QPI 速率 ) X 每 次 传输 的 有 效 数 据 ( 即 16b/8= 二 2B) X 双 向 。 所 以 QPI 速率 为 4.8GT/s 的 总 
市 宽 王 4.8GT/sX2BX2 王 19. 2GB/s,QPI 速率 为 6. 4GT/s 的 总 市 宽 王 6. 4GT/sX 2BX 
2 二 25. 6GB/s。 不 难 发 现 ,目前 的 QPI 比 以 前 最 宽 最 快 的 FSB 还 要 快 一 倍 。 


6. DMI 数据 传输 速率 


DMI 是 指 直 接 媒 体 接 口 (Direct Media Interface) 。 它 基于 PCI-Express 总 线 ( 详 见 第 8 
章 介 绍 ) ,并 跟随 PCI-E 总 线 的 更 新 而 换代 。DMI 采用 点 对 点 的 连接 方式 ,时 钟 频率 
为 100MHz。 


更 
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DMI 并 不 是 新 鲜 事物 , 在 没有 取消 FSB 时 ,DMI 就 是 Intel 公司 开发 用 于 北桥 和 南 桥 
之 间 的 芯片 连接 总 线 。DMI 实现 了 上 行 与 下 行 双 向 数据 传输 率 , 单 通道 单 向 传输 速率 达到 
2.5GT/s, 采 用 8b/10b 编码 ,共计 4 条 通道 。 

随 着 集成 电路 的 发 展 ,PCI-E 控制 希 也 被 整合 进 了 CPU ,这 样 一 来 ,相当 于 北桥 芯片 的 
功能 整个 都 集成 到 了 CPU 内 部 ,主板 上 看 不 到 北桥 芯片 的 踪影 ,只 剩 下 一 个 名 为 PCH( 平 
人 台 控 制 中 枢 ), 它 的 性 质 类 似 于 过 去 的 南 桥 , 它 与 CPU 之 间 不 需要 交换 太 多 数据 ,因此 连接 
总 线 采用 DMI 足够 了 , 故 FSB 被 DMI 取代 。 

随 着 PCI-E 总 线 的 升级 DMI 的 数据 传输 速率 在 不 断 提 高 ,DMI2.0 的 单 通 道 传 输 速率 
达到 5GT/s, 仍 采用 8b/10b 编码 ; DMI3. 0 的 单 通道 传输 速率 达到 8GT/s, 采 用 128b/130b 
编码 ,有 效 码 率 高 达 98. 46%% , 相 比 8b/10b 编码 的 80% 提 高 了 很 多 ，。 

DMI 总 线 市 宪 的 计算 公式 : 

理论 最 大 和 融 宽 (GB/s) 二 (传输 速率 X 编码 率 X 通 道 数 ) 二 8 

DMI 理论 最 大 带宽 ==(2. 5GT/sX8/10X4) 二 8 二 1GB/s 

DMI2. 0 理论 最 大 带宽 =(5GT/sX8/10X4) 二 8=2GB/s 

DMI3. 0 理论 最 大 带宽 二 (8GT/sX128/130X4) 二 8 二 3. 94GB/s 
Intel CPU 通过 FSB、QPI、.DMI 总 线 传输 数据 示意 如 图 6-3 所 示 。 


QPI 
内 存 控制 器 内 存 挥 制 器 北桥 
PCI-E 控 制 器 显卡 


(a) 通过 FSB 总 线 传输 (b) 通过 QPI 总 线 传输 


(c) 通过 DMI 总 线 传输 


6-3 ”Intel CPU 通过 FSB.QPI .DMI 总 线 传输 数据 


7. 片 内 Cache 的 容量 


片 内 Cache 又 称 CPU Cache, 它 的 容量 和 工作 速率 对 提高 计算 机 的 速度 起 着 关键 作 
用 。CPU Cache 可 以 分 为 L1 Cache、L2 Cache ,部 分 高 妆 CPU 还 具有 L3 Cache。 

L1 Cache: 位 于 CPU 内 核 的 旁边 ,是 与 CPU 结合 最 为 紧密 的 CPU 缓存 。 一 般 来 说 ， 
一 级 缓存 可 以 分 为 一 级 数据 缓存 (Data Cache, D-Cache) 和 一 级 指令 缓存 (JInstruction 
Cache,I-Cache)。 大 多 数 CPU 的 一 级 数据 缓存 和 一 级 指令 缓存 具有 相同 的 容量 。 例 如 ,D- 
Cache 和 [Cache 各 为 64KB, 总 容量 为 128KB。 

L2 Cache: 是 影响 CPU 性 能 的 关键 因素 之 一 ,在 CPU 核心 不 变化 的 情况 下 ,增加 L2 
Cache 的 容量 能 使 性 能 大 幅度 提高 ,而 同一 核心 CPU 的 高 低 端 之 分 往往 也 是 在 L2 Cache 


上 有 差异 。 目 前 CPU 的 L2 Cache 一 般 为 1MB, 容 量 可 达 4 一 8MEB。 

L3 Cache: 是 为 读 取 L2 Cache 后 未 命中 的 数据 设计 的 一 种 缓存 ,在 拥有 L3 Cache 的 
CPU 中 ,只 有 约 5% 的 数据 需要 从 内 存 中 调用 ,这 进一步 提高 了 CPU 的 效率 。L3 Cache 的 
容量 一 般 从 几 兆 字 节 至 几 十 兆 字 节 不 等 。 


8. 工作 电压 


工作 电压 指 的 是 CPU 正常 工作 所 需 的 电压 。 早 期 CPU 的 工作 电压 一 般 为 5V, 以 至 于 
CPU 的 发 热量 太 大 ,使 得 寿命 缩短 。 随 着 CPU 的 制造 工艺 与 内 频 的 提高 ,近年 来 各 种 
CPU 的 工作 电压 有 逐步 下 降 的 趋势 ,以 解决 发 热 问题 ,目前 一 般 台 式 计算 机 的 CPU 工作 电 
压 已 低 于 3V, 有 的 已 低 于 2V ;而 便携 式 计 算 机 专用 CPU 的 工作 电压 就 更 低 了 ,甚至 达到 
1.2V。 这 使 得 功 耗 大 大 减少 ,但 其 生产 成 本 也 大 为 提高 。 


9. 地 址 总 线 宽度 


地 址 总 线 宽度 决定 了 CPU 可 以 访问 的 最 大 的 物理 地 址 空间 ,简单 地 说 就 是 CPU 到 撒 
能 够 使 用 多 大 容量 的 主 存 。 例 如 , Pentium 有 32 位 地 址 线 , 可 寻 址 的 最 大 容量 为 22 = 
4096MB(4GB) ,而 Itantium 有 44 位 地 址 线 ,可 寻 址 的 最 大 容量 为 22 王 16TB。 


10. 数据 总 线 宽 度 


数据 总 线 宽度 决定 了 CPU 与 外 部 Cache、 主 存 以 及 输入 输出 设备 之 间 进 行 一 次 数据 传 
输 的 信息 量 。 如 果 数 据 总 线 为 32 位 , 则 每 次 最 多 可 以 读 写 主 存 中 的 32 位 ;如 果 数 据 总 线 为 
64 位 , 则 每 次 最 多 可 以 读 写 主 存 中 的 64 位 。 

数据 总 线 和 地 址 总 线 是 互相 独立 的 ,数据 总 线 宽度 指明 了 芯片 的 信息 传递 能 力 ,而 地 址 
总 线 宽 度 说 明了 芯片 可 以 访问 多 少 个 主 存单 元 。 


11. TDP 功 耗 


TDP 是 指 热 设 计 功 耗 (Thermal Design Power)。TDP 的 含义 是 当 处 理 器 达到 最 大 负 
荷 的 时 候 所 释放 出 的 热量 ,计量 单位 为 瓦 (W)。 这 是 反应 处 理 器 热量 释放 的 指标 ,是 计算 机 
的 冷却 系统 必须 有 人 能力 驱散 的 最 大 热量 限度 。 

TDP 功 耗 可 以 大 致 反映 出 CPU 的 发 热情 况 ,而 制约 CPU 发 展 的 一 个 重要 问题 就 是 散 
热 问 题 ,显然 发 热量 低 的 CPU 设计 有 望 达 到 更 高 的 工作 频率 ,目前 的 台式 计算 机 CPU 的 
TDP 功 耗 超过 100W 基本 是 不 可 取 的 ,比较 理想 的 数值 是 低 于 50W ;而 便携 式 计算 机 CPU 
的 TDP 功 耗 仅 15W 。 


12. 制造 工艺 


线 宽 是 指 芯 片 内 电路 与 电路 之 间 的 距离 ,可 以 用 线 宽 来 描述 制造 工艺 。 线 宽 越 小 ,就 意 
味 着 芯片 上 包括 的 晶体 管 数 目 越 多 。Pentium 开 的 线 宽 是 0. 35pm, 唱 体 管 数 达到 7. 5 兆 
个 ;Pentium 焉 的 线 宽 是 0.25pm, 唱 体 管 数 达到 9. 5 兆 个 ;Pentium 4 的 线 宽 是 0. 18pm , 品 
体 管 数 达 到 42 兆 个 。 目 前 主流 CPU 的 线 宽 45nm、32nm、22nm 和 14nm,7nm 的 制造 工艺 
将 是 新 一 代 CPU 的 发 展 目标 。 
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6.2 控制 器 的 组 成 和 实现 方法 
控制 器 是 计算 机 系统 的 指挥 中 心 , 它 把 运算 器 .存储 器 、 输 入 输出 设备 等 部 件 组 成 一 个 
有 机 的 整体 ,然后 根据 指令 的 要 求 指挥 全 机 的 工作 。 
6.2.1 控制 器 的 基本 组 成 


各 种 不 同类 型 计算 机 的 控制 天 会 有 不 少 差别 ,但 其 基本 组 成 是 相同 的 ,图 6-4 给 出 了 控 
制 大 的 基本 组 成 框图 ,控制 帮主 要 由 以 下 几 部 分 组 成 。 


微 操 作 命令 序列 


状态 信息 
0 台 自 做 操 作 程序 计数 器 (PC) 一 +1 
下 信号 发 生 器 
状态 寄存 器 | | 节拍 发 生 器 地 址 形成 部 件 | = 全 A 人 7 


一 人 


中 上 断 控制 好 辑 | 时钟 | 一 | | 操作 码 | 地 址 码 


指令 寄存 器 (IR) 
指令 ”中断 | 启 停 || 脉冲 
结束 请 求 | 逻辑 || 新 


6-4 控制 右 的 基本 组 成 


指令 部 件 的 主要 任务 是 完成 取 指 令 并 分 析 指 令 。 指 令 部 件 包 括 以 下 几 个 部 分 。 

(1) 程序 计数 大 

程序 计数 需 说 明 见 6.1.2 节 。 

(2) 指令 寄存 器 

指令 寄存 器 说 明 见 6. 1.2 节 。 

(3) 指令 译 码 笑 

指令 译 码 器 又 称 操作 码 译 码 右 或 指令 功能 分 析 解 释 器 。 暂 存在 指令 寄存 器 中 的 指令 ， 
只 有 在 其 操作 码 部 分 经 过 译 码 之 后 ,才能 识别 出 这 是 一 条 什么 样 的 指令 ,并 产生 相应 的 控制 
信号 提供 给 微 操作 信号 发 生 器 。 

(4) 地 址 形成 部 件 

地 址 形成 部 件 根 据 指 令 的 不 同 寻 址 方式 ,形成 操作 数 的 有 效 地 址 。 在 微型 和 小 型 机 中 ， 
可 以 不 设 专门 的 地 址 形成 部 件 , 而 利用 运算 器 来 进行 有 效 地 址 的 计算 。 


2. 时 序 部 件 


时 序 部 件 能 产生 一 定 的 时 序 信号 ,以 保证 机 禹 的 各 功能 部 件 有 节奏 地 进行 信息 传送 、 加 
工 及 信息 存储 。 时 序 部 件 包括 以 下 几 个 部 分 。 
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(1) 脉冲 源 

脉冲 源 用 来 产生 具有 一 定 频率 和 宽度 的 时 钟 脉冲 信号 ,为 整个 机 器 提供 基准 信号 。 为 
使 主 脉冲 的 频率 稳定 ,一般 都 使 用 石英 品 体 振 荡 咒 做 脉冲 源 。 当 计算 机 的 电源 一 接 通 ,脉冲 
源 立即 按 规定 的 频率 重复 发 出 具有 一 定 占 空 比 的 时 钟 脉冲 序列 ,直至 关闭 电源 为 止 。 

(2) 启 停 控 制 逻辑 

只 有 通过 启 停 控制 逻辑 将 计算 机 启动 后 , 主 时 钟 脉 冲 才 允许 进入 ,并 启动 节拍 信和 号 发 生 
帮 开 始 工 作 。 启 停 控 制 逻 辑 的 作用 是 根据 计算 机 的 需要 ,可 徘 地 开放 或 封锁 脉冲 ,控制 时 序 
信号 的 发 生 或 停止 ,实现 对 整个 机 器 的 正确 启动 或 停止 。 启 停 控 制 逻辑 保证 启动 时 输出 的 
第 一 个 脉冲 和 停止 时 输出 的 最 后 一 个 脉冲 都 是 完整 的 脉冲 。 

(3) 节拍 信号 发 生 器 

节拍 信号 发 生 器 又 称 脉 冲 分 配 咽 。 脉 冲 源 产 生 的 脉冲 信号 ,经 过 节拍 信号 发 生 器 后 产 
生出 各 个 机 器 周期 中 的 节拍 信号 ,用 以 控制 计算 机 完成 每 一 步 微 操作 。 


3. 微 操作 信号 发 生 器 


一 条 指令 的 取出 和 执行 可 以 分 解 成 很 多 最 基本 的 操作 ,这 种 最 基本 的 不 可 再 分 制 的 操 
作 称 为 微 操作 。 微 操作 信号 发 生 器 也 称 为 控制 单元 (CU)。 不 同 的 机 器 指令 具有 不 同 的 微 
操作 序列 。 


4. 中 断 控制 逻辑 
中 断 控制 还 辑 是 用 来 控制 中 断 处 理 的 硬件 逻辑 。 有 关中 断 的 问题 将 在 第 9 章 中 专门 介绍 。 
6.2.2 控制 器 的 硬件 实现 方法 


控制 硕 的 核心 是 微 操 作 信 号 发 生 天 (控制 单元 CU) ,图 6-5 是 反映 控制 单元 外 特性 的 框 
图 。 微 操作 控制 信号 是 由 指令 部 件 提 供 的 诺 码 信号 、 时 序 部 件 提 供 的 时 序 信号 和 被 控制 功 
能 部 件 所 反馈 的 状态 及 条 件 综合 形成 的 。 


做 操作 控制 信号 


各 部 件 状态 


反馈 信和 号 


微 操作 信和 号 发 生 硕 


操作 码 译 码 输出 
6-5 控制 单元 外 特性 


控制 单元 的 输入 包括 时 序 信 号 、 机 需 指 令 操 作 码 、 各 部 件 状态 反馈 信号 等 ,输出 的 微 操 
作 控 制 信号 又 可 细 分 为 CPU 内 的 控制 信号 和 送 至 主 存 或 外 设 的 控制 信号 。 根 据 产 生 微 操 
作 控 制 信号 的 方式 不 同 ,控制 希 可 分 为 组 合 逻辑 型 、 存 储 逻 辑 型 组合 逻 辑 与 存储 逻辑 结合 
型 3 种 ,它们 的 根本 区 别 在 于 控制 单元 的 实现 方法 不 同 ,而 控制 项 中 的 其 他 部 分 基本 上 是 大 
同 小 寞 的 。 


本 地 吕 吕 
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1. 组 合 逻 辑 型 控制 器 


这 种 控制 硕 称 为 稼 规 控 制 咒 或 便 连 线 控制 硕 , 是 采用 组 合 逻辑 技术 来 实现 的 ,其 控制 单 
元 是 由 门 电路 组 成 的 复杂 树 形 网 络 。 这 种 方法 是 分 立 元 件 时 代 的 产物 ,以 使 用 最 少 器 件数 
和 取得 最 高 操作 速度 为 设计 目标 。 

组 合 逻 辑 型 控制 需 的 最 大 优点 是 速度 快 。 但 是 ,组 合 逻辑 型 控制 需 控 制 单 元 的 结构 不 
规整 ,使 得 设计 、 调 试 、 维 修 较 困难 ,难以 实现 设计 自动 化 ;一 旦 控制 单元 构成 之 后 ,要 想 增 加 
新 的 控制 功能 是 不 可 能 的 。 因 此 , 它 受 到 微 程序 控制 融 的 强烈 冲击 。 目 前 , 仅 有 一 些 巨 型 机 
和 RISC 机 为 了 追求 高 速度 仍 采 用 组 合 逻辑 型 控制 硕 。 


2. 存储 逻辑 型 控制 器 


这 种 控制 带 称 为 微 程序 控制 大 ,是 采用 存储 逻辑 来 实现 的 ,也 就 是 把 微 操作 信号 代码 
化 ,使 每 条 机 天 指 令 转化 成 为 一 段 微 程序 并 存 人 一 个 专门 的 存储 希 ( 控 制 存储 硕 ) 中 , 微 操 作 
控制 信号 由 微 指令 产生 。 

微 程 序 控制 器 的 设计 思想 和 组 合 逻 辑 设计 思想 截然 不 同 。 它 具有 设计 规整 .调试 、 维 修 
以 及 更 改 .扩充 指令 方便 的 优点 ,易于 实现 月 动 化 设计 ,但 是 ,由 于 它 增 加 了 一 级 控制 存储 
船 , 所 以 指令 的 执行 速度 比 组 合 逻 辑 型 控制 郑 慢 。 


3. 组 合 逻 辑 和 存储 逻辑 结合 型 控制 器 


这 种 控制 硕 称 为 可 编程 逻辑 阵列 (PLA) 控 制 硕 ,是 吸收 前 两 种 方法 的 设计 思想 来 实现 
的 。PLA 控制 硕 实 际 上 也 是 一 种 组 合 逻辑 型 控制 需 , 但 它 又 与 第 规 的 组 合 逻辑 型 控制 硕 的 
便 联 结构 不 同 ; 它 是 可 编程 序 的 , 某 一 微 操 作 控 制 信号 由 PLA 的 某 一 输出 函数 产生 。 

PLA 控制 硕 是 组 合 逻 辑 技 术 和 存储 逻辑 技术 结合 的 产物 ,克服 了 两 者 的 缺点 ,是 一 种 
较 有 前 途 的 方法 。 


6.3 时 序 系统 与 控制 方式 


由 于 计算 机 高 速 地 进行 工作 ,每 一 个 动作 的 时 间 是 非 徊 严格 的 ,不 能 有 任何 差错 。 时 序 
系统 是 控制 大 的 心脏 ,其 功能 是 为 指令 的 执行 提供 各 种 定时 信号 。 


6.3.1 时 序 系统 
1. 指令 周期 和 机 器 周期 


指令 周期 是 指 从 取 指 令 、 分 析 取 数 到 执行 完 该 指令 所 需 的 全 部 时 间 。 由 于 各 种 指令 的 
操作 功能 不 同 , 有 的 简单 ,有 的 复杂 ,因此 各 种 指令 的 指令 周期 不 尽 相 同 。 
机 天 周 期 又 称 CPU 周期 。 通 第 把 一 个 指令 周期 划分 为 右 干 个 机 融 周 期 ,每 个 机 天 周 
期 完成 一 个 基本 操作 。 一 般 机 带 的 CPU 周期 有 取 指 周期 \ 取 数 周期 执行 周期 和 中 断 周期 
等 。 所 以 有 : 
指令 周期 =iX 机 絮 周 期 
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不 同 的 指令 周期 中 所 包含 的 机 天 周 期 数 差别 可 能 很 大 。 一 般 情况 下 ,一 条 指令 所 需 的 
最 短 时 间 为 两 个 机 带 周 期 : 取 指 周期 和 执行 周期 。 

通常 ,每 个 机 带 周 期 部 有 一 个 与 之 对 应 的 周期 状态 触发 天 。 机 带 运 行 在 不 同 的 机 带 周 
期 时 ,其 对 应 的 周期 状态 触发 带 被 置 “1”。 显 然 , 在 机 旭 运 行 的 任何 时 刻 只 能 处 于 一 种 周期 
状态 ,因此 ,有 一 个 且 仅 有 一 个 触发 大 被 置 “1”。 

由 于 CPU 内 部 的 操作 速度 较 快 ,而 CPU 访问 主 存 所 花 的 时 间 较 长 ,所 以 许多 计算 机 
系统 往往 以 主 存 的 工作 周期 ( 存 取 周 期 ) 为 基础 来 规定 CPU 周期 ,以 便 两 者 的 工作 能 配合 
协调 。CPU 访问 主 存 也 就 是 一 次 总 线 传 送 , 故 在 微型 计算 机 中 称 为 总 线 周 期 。 


2. 节拍 


在 一 个 机 需 周 期 内 ,要 完成 若干 个 微 操作 。 这 些微 操作 有 的 可 以 同时 执行 ,有 的 需要 按 
先后 次 序 串 行 执行 。 因 而 应 把 一 个 机 需 周 期 分 为 奋 干 个 相等 的 时 间 自 ,每 一 个 时 间 段 对 应 
一 个 电位 信号 , 称 为 节拍 电位 信和 号。 

节拍 的 宽度 取决 于 CPU 完成 一 次 微 操 作 ( 如 ALU 一 次 正确 的 运算 、 寄 存 器 间 的 一 次 
传送 等 ) 的 时 间 。 

由 于 不 同 的 机 融 周 期 内 需要 完成 的 微 操 作 内 容 和 个 数 是 不 同 的 ,因此 ,不 同 机 需 周 期 内 
所 需要 的 节拍 数 也 不 相同 。 节 拍 的 选取 一 般 有 以 下 几 种 方法 。 

(1) 统一 节操 法 

以 最 复杂 的 机 帮 周 期 为 准 定 出 市 拍 数 ,每 一 个 节 哲 时 间 的 长 短 也 以 最 繁 的 微 操作 作为 
标准 。 这 种 方法 采用 统一 的 ,具有 相等 时 间 间 隐 和 相同 数目 的 节拍 ,使 得 所 有 的 机 器 周期 长 
度 都 是 相等 的 ,因此 称 为 定 长 CPU 周期 。 

(2) 分 散 节拍 法 

按照 机 器 周期 的 实际 需要 安排 节拍 数 , 需 要 多 少 节拍 就 发 出 多 少 节 拍 , 这 样 可 以 避免 浪 
费 ,提高 时 间 利 用 率 。 巾 于 各 机 硕 周 期 长 度 不 同 , 故 称 为 不 定 长 CPU 周期 。 

(3) 延长 节拍 法 

在 照顾 多 数 机 需 周期 要 求 的 情况 下 ,选取 适当 的 节拍 数 作为 基本 节拍 。 如 果 在 某 个 机 
器 周期 内 统一 的 节拍 数 无 法 完成 该 周期 的 全 部 微 操作 , 则 可 以 延长 一 或 两 个 节拍 。 

(4) 时 钟 周 期 插入 法 

在 一 些微 型 计算 机 中 ,时 序 信号 中 不 设置 节拍 ,而 直接 使 用 时 钟 周期 信和 号。 一 个 机 器 周 
期 中 含有 若干 个 时 钟 周 期 ,时 钟 周 期 的 数目 取决 于 机 器 M 
周期 内 完成 微 操作 数目 的 多 少 及 相应 功能 部 件 的 速度 。 1 Lb BB & 

一 个 机 各 周期 的 基本 时 钟 周期 数 确定 之 后 ,还 可 以 不 断 

插入 等 待 时 钟 周 期 。 例 如 ,8086 的 一 个 总 线 周期 ( 即 机 器 1 
周期 ) 中 包含 4 个 基本 时 钟 周 期 Tj 一 T ,在 T3 和 TT 之 间 

可 以 插入 任意 个 等 待 时 钟 周期 Tw ,以 等 待 速度 较 慢 的 存 

储 部 件 或 外 部 设备 完成 读 或 写 操作 ,如 图 6-6 所 示 。 图 6-6 ”时钟 周 期 的 插入 


3. 工作 脉冲 
在 节拍 中 执行 的 有 些微 操作 需要 同步 定时 脉冲 ,如 将 稳定 的 运算 结果 打 人 寄存 需 , 又 如 


下 地 吕 加 
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机 器 周期 状态 切换 等 。 为 此 ,在 一 个 节拍 内 常常 设置 一 个 或 几 个 工作 脉冲 作为 各 种 同步 肪 
冲 的 来 源 。 工 作 脉 冲 的 宽度 只 占 节拍 电位 宽度 的 一 ,并 处 于 节拍 的 末尾 部 分 ,以 保证 所 有 


的 触发 需 都 能 可 菲 、 稳 定 地 翻 苞 。 
在 只 设置 机 带 周 期 和 时 钟 周 期 的 微型 计算 机 中 ,一 般 不 再 设置 工作 脉冲 ,因为 时 钟 周期 
阮 可 以 作为 电位 信号 ,其 前 、 后 沿 又 可 以 作为 脉冲 触发 信号 。 


4. 多 级 时 序 系 统 


图 6-7 为 小 型 计算 机 每 个 指令 周期 中 稼 采用 的 机 需 周 期 、 节 担 . 工作 脉冲 三 级 时 序 系 
统 。 图 中 每 个 机 器 周期 M 中 包括 4 个 节拍 Ti 一 T ,每 个 节拍 内 有 一 个 脉冲 P。 在 机 器 周 
期 间 .节拍 电位 间 、 工 作 脉 冲 间 既 不 允许 有 重 酸 交 叉 ,也 不 允许 有 空 际 ,应 该 是 一 个 接 一 个 的 
准确 连接 。 


图 6-7 三 级 时 序 系统 


微型 计算 机 中 第 用 的 时 序 系统 与 小 型 机 的 略 有 不 同 , 称 为 时 钟 周期 时 序 系统 。 一 个 指 
令 周 期 包含 右 干 个 机 需 周 期 ,一 个 机 需 周 期 又 包含 右 干 个 时 钟 周期 。 


5. 节拍 电位 和 工作 脉冲 的 时 间 配 合 关 系 


在 计算 机 中 ,节拍 电位 和 工作 脉冲 所 起 的 控制 作用 是 不 同 的 。 电 位 信号 是 信息 的 载 
体 , 即 控制 信号 , 它 在 数据 通路 传输 中 起 着 开门 或 
关门 的 作用 ;工作 脉冲 则 作为 打 入 脉冲 加 在 触发 
器 的 脉冲 输入 端 ,起 到 定时 触发 的 作用 。 通 常 , 触 
发 器 使 用 电位 一 脉冲 工作 方式 ,节拍 电位 控制 信 
息 送 到 了 D 触发 需 的 D 输 入 端 ,工作 脉冲 送 到 CP 
输入 端 。 节拍 电 位 和 工作 脉冲 配合 关系 如 图 6-8 


示 信息 节拍 打 入 工作 
所 未。 电位 T， 条 件 脉冲 P 
6.3.2 控制 方式 图 6-8 节拍 电位 和 工作 脉冲 的 配合 关系 


CPU 的 控制 方式 可 以 分 为 以 下 3 种 。 


1. 同步 控制 方式 


同步 控制 方式 即 固定 时 序 控制 方式 ,各 项 操作 都 由 统一 的 时 序 信号 控制 ,在 每 个 机 需 周 
期 中 产生 统一 数目 的 节拍 电位 和 工作 脉冲 。 由 于 不 同 的 指令 ,操作 时 间 长 短 不 一 致 。 同 步 
控制 方式 应 以 最 复杂 指令 的 操作 时 间作 为 统一 的 时 间 间 隅 标准 。 

同步 控制 方式 设计 简单 ,容易 实现 ;但 是 ,对 于 许多 简单 指令 来 说 这 种 控制 方式 会 有 较 
多 的 空 闪 时 间 , 造 成 较 大 数量 的 时 间 浪 费 , 从 而 影响 了 指令 的 执行 速度 。 

在 同步 控制 方式 中 ,各 指令 所 需 的 时 序 由 控制 右 统 一 发 出 ,所 有 微 操作 都 与 时 钟 同 步 ， 
所 以 又 称 为 集中 控制 方式 或 中 央 控 制 方式 。 


2. 异步 控制 方式 


异步 控制 方式 即 可 变 时 序 控制 方式 ,各 项 操作 不 采用 统一 的 时 序 信号 控制 ,而 根据 指令 
或 部 件 的 具体 情况 决定 ,需要 多 少时 间 就 占用 多 少时 间 。 

这 是 一 种 “应 答 ” 方 式 ,各 操作 之 间 的 衔接 是 由 “结束 一 起 始 ” 信 号 来 实现 的 。 由 前 一 项 
操作 已 经 完成 的 “结束 ”信号 ,或 由 下 一 项 操作 的 “准备 好 ”信号 来 作为 下 一 项 操作 的 起 始 信 
号 ,在 未 收 到 “结束 ”或 “准备 好 ”信号 之 前 不 开始 新 的 操作 。 例 如 ,存储 器 读 操 作 时 ,CPU 辕 
存储 器 发 一 个 读 命令 (起 始 信号 ) ,启动 存储 器 内 部 的 时 序 信 号 ,以 控制 存储 器 读 操作 ,此 时 
CPU 处 于 等 待 状态 。 当 存储 器 操作 结束 后 ,存储 器 问 CPU 发 出 MFC( 结 束 信号 ), 以 此 作 
为 下 一 项 操作 的 起 始 信号 。 

异步 控制 采用 不 同时 序 , 没 有 时 间 上 的 浪费 ,因而 提高 了 机 器 的 效率 ,但 是 控制 比较 

由 于 这 种 控制 方式 没有 统一 的 时 钟 ,而 是 由 各 功能 部 件 本 身 产 生 各 上 自 的 时 序 信和 号 月 我 
控制 ,所 以 又 称 为 分 散 控 制 方式 或 局 部 控制 方式 。 


3. 联合 控制 方式 


联合 控制 方式 是 同步 控制 和 异步 控制 相 结合 的 方式 。 实 际 上 现代 计算 机 中 几乎 没有 完全 
采用 同步 或 完全 采用 异步 的 控制 方式 ,大 多 数 是 采用 联合 控制 方式 。 通 常 的 设计 思想 是 ; 在 
功能 部 件 内 部 采用 同步 方式 或 以 同步 方式 为 主 的 控制 方式 ,在 功能 部 件 之 间 采 用 异步 方式 。 

例如 ,在 一 般 小 型 和 微型 计算 机 中 ,CPU 内 部 基本 时 序 采 用 同步 方式 , 按 多 数 指令 的 需 
要 设置 节拍 数 。 对 于 某 些 复杂 指令 如 果 节 拍 数 不 够 ,可 采取 延长 节拍 等 方法 ,以 满足 指令 的 
要 求 。 当 CPU 通过 总 线 癌 主 存 或 其 他 外 设 交 换 数据 时 ,就 转 入 异步 方式 。CPU 只 需 给 出 
起 始 信 号 , 主 存 和 外 设 按 自己 的 时 序 信 号 去 安排 操作 ;一 旦 操作 结束 , 则 向 CPU 发 结束 信 
号 ,以 便 CPU 再 安排 它 的 后 继 工作 。 


6.3.3 指令 运行 的 基本 过 程 
一 条 指令 运行 过 程 可 以 分 为 3 个 阶段 : 取 指令 阶段 、 分 析 取 数 阶段 和 执行 阶段 。 
. 取 指 令 阶段 
取 指 令 阶段 完成 的 任务 是 将 现行 指令 从 主 存 中 取出 来 并 送 至 指令 寄存 器 中 ,具体 的 操 


一 


计算 机 组 成 原理 (第 4 版) 


作 如 下 : 

@ 将 程序 计数 器 (PC) 中 的 内 容 送 至 存储 器 地 址 寄存 器 (MAR) ,并 送 地 址 总 线 CAB) 。 

@ 由 控制 单元 (CU) 经 控制 总 线 (CB) 向 存储 器 发 读 命令 。 

@) 从 主 存 中 取出 的 指令 通过 数据 总 线 (DB) 送 到 存储 器 数据 寄存 器 (MDR ) 。 

@ 将 MDR 的 内 容 送 至 指令 寄存 需 (IR) 中 。 

@ 将 PC 的 内 容 递增 ,为 取 下 一 条 指令 做 好 准备 。 

以 上 这 些 操作 对 任何 一 条 指令 来 说 都 是 必须 要 执行 的 操作 ,所 以 称 为 公共 操作 。 
完成 取 指 阶段 任务 的 时 间 称 为 取 指 周期 ,图 6-9 给 出 了 取 指 周期 中 CPU 各 部 分 的 工作 
流程 。 


6-9” 取 指 周 期 中 CPU 各 部 分 的 工作 流程 


2. 分 析 取 数 阶段 


取出 指令 后 ,指令 详 码 豆 (ID) 可 识别 和 区 分 出 不 同 的 指令 类 型 。 此 时 计算 机 进入 分 析 
取 数 阶段 ,以 获取 操作 数 。 由 于 各 条 指令 功能 不 同 , 寻 址 方式 也 不 同 , 所 以 分 析 取 数 阶 段 的 
操作 是 各 不 相同 的 。 

对 于 无 操作 数 指 令 , 只 要 识别 出 是 哪 条 具体 的 指令 即 可 直接 转 至 执行 阶段 ,所 以 无 须 进 
入 分 析 取 数 阶段 。 而 对 于 市 操作 数 指令 ,为 读 取 操作 数 , 首 先 要 计算 出 操作 数 的 有 效 地 址 。 
如 宋 操作 数 在 通用 寄存 融 中 , 则 不 需要 再 访问 主 存 ; 如 果 操 作 数 在 主 存 中 , 则 要 到 主 存 中 去 
取 数 。 对 于 不 同 的 寻 址 方式 ,有 效 地 址 的 计算 方法 是 不 同 的 ,有 时 要 多 次 访问 主 存 才能 取出 
操作 数 来 (间接 寻 址 )。 男 外 , 单 操作 数 指令 和 双 操 作 数 指令 由 于 需要 的 操作 数 的 个 数 不 同 ， 
分 析 取 数 阶段 的 操作 也 不 同 。 

完成 分 析 取 数 阶 段 任务 的 时 间 又 可 以 细 分 为 间 址 周期 \ 取 数 周期 等 。 


执行 阶段 完成 指令 规定 的 各 种 操作 ,形成 稳定 的 运算 结果 ,并 将 其 存储 起 来 。 完 成 执行 
阶段 任务 的 时 间 称 为 执行 周期 。 

计算 机 的 基本 工作 过 程 就 是 取 指 令 、 取 数 .执行 指 令 , 然 后 再 取 下 一 条 指令 …… 如 此 周 
而 复 始 ,直至 过 到 停机 指令 或 外 来 的 干预 为 止 。 


6.3.4 指令 的 微 操作 序列 


因 央 处 理 器 


控制 带 在 实现 一 条 指令 的 功能 时 ,总 要 把 每 条 指令 分 解 成 一 系列 时 间 上 先后 有 序 的 最 
基本 、 最 简单 的 微 操作 , 即 微 操作 序列 。 微 操作 序列 是 与 CPU 的 内 部 数据 通路 密切 相关 


的 ,不 同 的 数据 通路 就 有 不 同 的 人 微 操 作 序 列 。 


假设 某 计 算 机 的 数据 通路 如 图 6-10 所 示 。 规 定 各 部 件 用 大 写字 母 表示 ,字母 加 下 标 in 
表示 该 部 件 的 接收 控制 信号 ,实际 上 就 是 该 部 件 的 输入 开门 信号 ;字母 加 下 标 out 表示 该 部 
件 的 发 送 控制 信号 ,实际 上 就 是 该 部 件 的 输出 开门 信号 。 例 如 ,MAR;。PC。 等 就 是 这 类 微 


操作 信号 。 下 面 分 析 具 体 指 令 发 出 的 微 操 作 控 制 信号 。 
控制 信号 
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图 6-10 CPU 的 数据 通路 


1. 加 法 指令 ADDCQ R, ,R， 


这 条 指令 完成 的 功能 是 把 Re 的 内 容 作 为 地 址 送 到 主 存 以 取得 一 个 操作 数 , 再 与 Ri 中 


的 内 容 相 加 ,最 后 将 结果 送 回 主 存 中 。 即 实现 : 
((Ro。)) 十 (Ri ) 一 (R。) 


地 吕 加 
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(1) 取 指 周期 

取 指 周期 完成 的 微 操作 序列 是 公共 的 操作 ,与 具体 指令 无 关 。 

JW PC。 和 MAR 有效, 完成 PC 的 内 容 ( 即 指令 地 址 ) 经 CPU 内 部 总 线 送 至 MAR 的 
操作 , 记 作 (PC) 一 MAR。 

@ 通过 控制 总 线 ( 图 中 未 画 出 ) 向 主 存 发 读 命令 , 记 作 Read。 

G) 存储 需 通 过 数据 总 线 将 MAR 所 指 单元 的 内 容 ( 指 令 ) 送 至 MDR, 记 作 MGCOMAR)- 一 MDR。 

由 MDR。. 和 IRi 有 效 , 将 MDR 的 内 容 送 至 指令 寄存 器 , 记 作 (MDR) 一 IR。 至 此 ,指令 
被 从 主 存 中 取出 ,其 操作 码 字 段 经 过 指令 译 码 器 开始 控制 CU。 

@ 使 PC 内容 加 1, 记 作 (PC) 十 1-PC。 

(2) 取 数 周期 

取 数 周期 要 完成 从 主 存 中 取 操 作 数 的 任务 ,此 时 另 一 个 操作 数 已 放 在 寄存 器 Ri 中 。 

QD Roowr 和 MAR 有效 ,完成 将 被 加 数 地 址 送 至 MAR 的 操作 , 记 作 CR。) 一 MAR。 

多 癌 主 存 发 读 命令 , 记 作 Read。 

@ 存储 器 通过 数据 总 线 将 MAR 所 指 单元 的 内 容 ( 即 数据 ) 送 至 MDR ,同时 MDR。. 和 
Yi 有效, 记 作 M(MAR) 一 MDR>Y，。 

(3) 执行 周期 

执行 周期 完成 加 法 运算 的 任务 ,并 将 结果 写 回 主 存 。 

QO Ri 和 ALU 有 效 , 同 时 CU 向 ALU 发 "ADD? 控 制 信号 ,使 Ri 的 内 容 和 YY 的 内 容 
相 加 ,结果 送 寄 存 器 Z, 记 作 (CR ) 十 (Y) 一 Z。 

@ Z. 和 MDRi;, 有 效 ,将 运算 结果 送 MDR , 记 作 (Z) 一 MDR。 

G@) 问 主 存 发 写 命 令 , 记 作 Write。 


2. 转移 指令 JC A 


这 是 一 条 条 件 转移 指令 ,各 上 次 运算 结果 有 进位 (C= 二 1), 就 转移; 帮 上 次 运算 结果 无 进 
位 (C==0) ,就 顺序 执行 下 一 条 指令 。 设 A 为 位 移 量 ,转移 地 址 等 于 PC 的 内 容 加 位 移 量 。 
相应 的 微 操作 序列 如 下 。 

(1) 取 指 周期 

与 上 条 指令 的 微 操作 序列 完全 相同 。 

(2) 执行 周期 

如 果 有 进位 (C==1), 则 完成 (PC) 十 A 一 PC 的 操作 ,否则 跳 过 以 下 几 步 。 

@ PC 和 Yi 有 效 , 记 作 (PC) 一 Y(C=1) 。 

@ Ad IR。.. 和 ALUi 有 效 , 同 时 CU 向 ALU 发 ‘ADD” 控 制 信号 ,使 IR 中 的 地 址 码 字段 
A 和 YY 的 内 容 相 加 ,结果 送 寄 存 器 Z, 记 作 Ad(IR) 十 (Y) 一 Z(CC 王 1) 。 

@ Zo 和 PC 有效 ,将 转移 地 址 送 入 PC, 记 作 (Z) 一 PC(C=1)。 


6.4 微 程序 控制 原理 


微 程 序 设计 技术 的 实质 是 将 程序 设计 技术 和 存储 技术 相 结 合 , 即 用 程序 设计 的 思想 方 
法 来 组 织 操作 控制 逻辑 ,将 微 操 作 控 制 信号 按 一 定 规则 进行 信息 编码 (代码 化 ) ,形成 控制 字 


因 央 处 理 器 


( 微 指令 ) ,再 把 这 些微 指令 按时 间 先 后 排列 起 来 构成 微 程 序 , 存 放 在 一 个 只 读 的 控制 存储 
傣 中 。 


6.4.1 微 程 序 控制 的 基本 概念 
1. 微 程序 设计 的 提出 与 发 展 


微 程 序 设计 的 概念 和 原理 最 早 是 由 英国 剑桥 大 学 的 M. V. Wilkes 教授 于 1951 年 提出 
来 的 。 他 在 《4 设计 自动 化 计算 机 的 最 好 方法 ) 中 指出 : 一 条 机 需 指 令 可 以 分 解 为 许多 基本 的 
微 命 令 序 列 , 并 且 首 先 把 这 种 思想 用 于 计算 机 控制 器 的 设计 。 但 是 ,由 于 当时 还 不 具备 制造 
专门 存放 微 程序 的 控制 存储 天 的 技术 ,所 以 在 十 几 年 时 间 内 实际 上 并 未 真正 使 用 。 直 到 
1964 年 ,IBM 公司 在 IBM360 系列 机 上 成 功 地 采用 了 微 程 序 设 计 技 术 ,解决 了 指令 系统 的 
兼容 问题 。20 世纪 70 年 代 以 来 ,由 于 VLSI 技术 的 发 展 , 推 动 了 微 程序 设计 技术 的 发 展 和 
应 用 ,目前 大 多 数 计 算 机 都 采用 微 程序 设计 技术 。 


2. 基本 术语 


(1) 微 命 令 和 微 操作 

前 面 已 经 提 到 ,一 条 机 器 指令 可 以 分 解 成 一 个 微 操 作 序 列 , 这 些微 操作 是 计算 机 中 最 基本 
的 、 不 可 再 分 解 的 操作 。 在 微 程序 控制 的 计算 机 中 ,将 控制 部 件 癌 执行 部 件 发 出 的 各 种 控制 命 
令 称 为 微 命令 , 它 是 构成 控制 序列 的 最 小 单位 。 例 如 ,打开 或 关闭 某 个 控制 门 的 电位 信号 、 某 
个 寄存 融 的 打 入 脉冲 等 。 因 此 , 微 命令 是 控制 计算 机 各 部 件 完 成 某 个 基本 微 操作 的 命令 。 

微 命令 和 微 操 作 是 一 一 对 应 的 。 微 命令 是 微 操 作 的 控制 信号 , 微 操 作 是 微 命令 的 操作 
过 程 。 

微 命 令 有 兼容 性 和 互 斥 性 之 分 。 兼 容 性 微 命 令 是 指 那 些 可 以 同时 产生 ,共同 完成 某 一 
些微 操作 的 微 命令 ;而 互 斥 性 微 命 令 是 指 在 机 需 中 不 允许 同时 出 现 的 微 命 令 。 兼 容 和 互 矿 
都 是 相对 的 ,一 个 微 命令 可 以 和 一 些微 命令 兼容 ,和 男 一 些微 命令 互 斥 。 对 于 单独 一 个 微 命 
令 ,谈论 其 兼容 和 互 帮 都 是 没有 意义 的 。 

(2) 微 指令 、 微 地 址 

微 指 令 是 指控 制 存 储 硕 中 的 一 个 单元 的 内 容 , 即 控制 字 ,是 奋 干 个 微 命 令 的 集合 。 存 放 
控制 字 的 控制 存储 希 的 单元 地 址 就 称 为 微 地址 。 

一 条 微 指令 通常 至 少 包含 两 部 分 信息 : 

Q@ 操作 控制 学 段 ,又 称 微 操作 码 字 段 ,用 以 产生 某 一 步 操 作 所 需 的 各 微 操作 控制 信号 

@ 顺序 控制 学 段 ,又 称 微 地 址 码 字 段 ,用 以 控制 产生 下 一 条 要 执行 的 微 指 令 地 址 。 

微 指 令 有 垂直 型 和 水 平 型 之 分 。 垂 直 型 微 指令 接近 于 机 需 指 令 的 格式 ,每 条 微 指 令 只 
能 完成 一 个 基本 微 操 作 ; 水 平 型 微 指令 则 具有 良好 的 并 行 性 ,每 条 微 指 令 可 以 完成 较 多 的 基 
本 微 操作 。 

(3) 微 周期 

从 控制 存储 器 中 读 取 一 条 微 指 令 并 执行 相应 的 微 命令 所 需 的 全 部 时 间 称 为 微 周 期 。 

(4) 微 程序 

一 系列 微 指 令 的 有 序 集合 就 是 微 程序 。 每 一 条 机 需 指 令 都 对 应 一 个 微 程序 。 
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注意 : 微 程序 和 程序 是 两 个 不 同 的 概念 。 微 程序 是 由 微 指 令 组 成 的 ,用 于 描述 机 器 指 
令 , 微 程序 实际 上 是 机 器 指令 的 实时 解释 器 ,是 由 计算 机 的 设计 者 事先 编制 好 并 存放 在 控制 
存储 器 中 的 ,一般 不 提供 给 用 户 。 对 于 程序 员 来 说 ,计算 机 系统 中 微 程序 一 级 的 结构 和 功能 
是 透明 的 ,无 须知 道 。 而 程序 最 终 由 机 器 指令 组 成 ,是 由 软件 设计 人 员 事 先 编制 好 并 存放 在 
主 存 或 辅 存 中 的 。 所 以 说 , 微 程序 控制 的 计算 机 涉及 两 个 层次 : 一 是 机 器 语言 或 汇编 语言 
程序 员 所 看 到 的 传统 机 器 层 , 包 括 机 器 指令 、 工 作 程 序 和 主 存 储 器 ;二 是 机 器 设计 者 看 到 的 
微 程序 层 , 包 括 微 指令 、 微 程序 和 控制 存储 器 。 


6.4.2 人 微 指令 编码 法 


微 指 令 可 以 分 成 操作 控制 字段 和 顺序 控制 字段 两 部 分 。 这 里 所 说 的 币 指 令 编码 法 指 的 
就 是 操作 控制 字段 的 编码 方法 。 各 类 计算 机 从 各 日 的 特点 出 发 ,设计 了 各 种 各 样 的 微 指令 
编码 法 。 例 如 ,大 型 机 强调 速度 ,要 求 译 码 过 程 尽量 快 ;微型 机 和 小 型 机 则 更 多 地 注意 经 济 
性 ,要 求 更 大 限度 地 缩短 微 指 令 字 长 ;而 中 型 机 介 于 这 两 者 之 间 ,兼顾 速度 和 价格 ,要求 在 保 
证 一 定 速 度 的 情况 下 ,能 尽量 缩短 微 指 令 字 长 。 下 面 从 基本 原理 出 发 ,对 几 种 基本 的 微 指令 
编码 方法 进行 讨论 。 


1. 直接 控制 法 (不 译 码 法 ) 


直接 控制 法 顾名思义 是 操作 控制 字段 中 的 各 位 分 别 可 以 直接 控制 计算 机 ,无须 进行 详 
码 。 在 这 种 形式 的 微 指令 字 中 ,操作 控制 字段 的 每 一 个 独立 的 二 进 制 位 代表 一 个 微 命 令 ,该 
位 为 “1” 表 示 这 个 微 命令 有 效 ,为 “0” 则 表示 这 个 微 命令 无 效 。 每 个 微 命 令 对 应 并 控制 数据 
通路 中 的 一 个 微 操作 。 

这 种 方法 结构 简单 ,并 行 性 强 , 操 作 速 度 快 ,但 是 微 指 令 字 太 长 。 硅 微 命 令 的 总 数 为 
NN 个 , 则 微 指 令 字 的 操作 控制 字段 就 要 有 N 位 。 在 某 些 计算 机 中 , 微 命 令 的 总 数 可 能 会 多 
达 三 、 四 百 个 ,甚至 更 多 ,这 使 微 指令 的 长 度 达 到 难以 接受 的 地 步 。 男 外 ,在 NN 个 微 命 令 中 ， 
有 许多 是 互 斥 的 ,不 允许 并 行 操作 ,将 它们 安排 在 一 条 微 指令 中 是 毫 无 意义 的 ,只 会 使 信息 
的 利用 率 下 降 。 所 以 ,这 种 方法 在 复杂 的 系统 中 很 少 单独 采用 ,往往 与 其 他 编码 方法 混合 起 
来 使 用 。 


2. 最 短 编码 法 


直接 控制 法 使 微 指 令 字 过 长 ,而 最 短 编码 法 则 走向 男 一 个 极端 ,使 得 微 指 令 字 最 短 。 这 
种 方法 将 所 有 的 微 命令 统一 编码 ,每 条 微 指 令 只 定义 一 个 微 命令 。 夺 微 命令 的 总 数 为 N， 
操作 控制 字段 的 长 度 为 L, 则 最 短 编码 法 应 满足 下 列 关系 式 : 

L 宇 log,s N 

最 短 编码 法 的 微 指 令 字 长 最 短 ,但 要 通过 一 个 微 命令 译 码 副 译 码 以 后 才能 得 到 需要 的 
微 命令 。 微 命令 数目 越 多 , 译 码 右 就 越 复 杂 。 这 种 方法 在 同一 时 刻 只 能 产生 一 个 微 命令 ,不 
er tp en 
要 求 在 同一 时 刻 同 时 动作 的 组 合 性 微 操作 将 无 法 实现 。 因 此 ,这 种 方法 也 只 能 与 其 他 方法 
混合 使 用 。 
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3. 字段 编码 法 


这 是 前 述 两 种 编码 法 的 一 个 折 中 的 方法 , 既 具 有 两 者 的 优点 ,又 克服 了 它们 的 缺点 。 这 
种 方法 将 操作 控制 字段 分 为 奉 干 个 小 段 ,每 段 内 采用 最 短 编码 法 , 段 与 段 之 间 采 用 直接 控制 
法 。 这 种 方法 又 可 进一步 分 为 字段 直接 编码 法 和 字段 间接 编码 法 。 

(1) 字段 直接 编码 法 

图 6-11 为 字段 直接 编码 法 的 微 指令 绪 构 ,各 字段 都 可 以 独立 地 定义 本 字段 的 微 命 令 
而 和 其 他 字段 无 关 , 因 此 又 称 为 显 式 编码 或 单 重 定 义 编码 方法 。 这 种 方法 缩短 了 微 指令 字 ， 
因此 得 到 了 广泛 的 应 用 。 
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操作 控制 字段 顺序 控制 字段 
图 6-11 字段 直接 编码 法 


(2) 字段 间接 编码 法 

字段 间接 编码 法 是 在 字段 直接 编码 法 的 基础 上 ,用 来 进一步 缩短 微 指令 字 长 的 方法 。 
间接 编码 的 含义 是 ,一 个 字段 的 某 些 编码 不 能 独立 地 定义 某 些 微 命 令 ,而 需要 与 其 他 字段 的 
编码 来 联合 定义 ,因此 又 称 为 隐 式 编码 或 多 重 定 义 编 码 方法 ,如 图 6-12 所 示 。 


图 6-12 字段 间接 编码 法 


图 6-12 中 字段 A( 假 设 3 位 ) 所 产生 的 微 命 令 还 要 受到 字段 B 的 控制 。 当 字段 B 发 出 
bi 微 命 令 时 ,字段 A 与 其 合作 产生 as az、…、\ar 中 的 一 个 微 命 令 ;而 当 字 段 B 发 出 b: 微 
命令 时 ， 字段 A 与 其 合作 产生 al,2\ a2,2、  、\a7， :中 的 男 一 个 微 命令 。 这 种 方法 进 一 步 减 少 了 
微 指 令 的 长 度 , 但 通常 可 能 会 削弱 微 指 令 的 并 行 控制 能 力 , 且 详 码 电 路 相应 地 较 复 杂 ,因此 ， 
它 只 作为 字段 直接 编码 法 的 一 种 补充 。 

字段 编码 法 中 操作 控制 字段 的 分 段 并非 是 任意 的 ,必须 要 遵循 如 下 原则 : 

J 把 互 斥 性 的 微 命 令 分 在 同一 段 内 ,兼容 性 的 微 命 令 分 在 不 同 段 内 。 这 样 不 仅 有 助 于 提高 
信息 的 利用 率 , 缩 短 微 指令 字 长 ,而 且 有 助 于 充分 利用 人 硬件 所 具有 的 并 行 性 ,加快 执行 的 速度 。 
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GO 应 与 数据 通路 结构 相 适 应 。 

@) 每 个 小 段 中 包含 的 信息 位 不 能 太 多 ,否则 将 增加 译 码 线路 的 复杂 性 和 译 码 时 间 。 

一 般 每 个 小 段 还 要 留 出 一 个 状态 ,表示 本 字段 不 发 出 任何 微 命 令 。 因 此 , 当 某 字段 
的 长 度 为 3 位 时 ,最 多 只 能 表示 7 个 互 斥 的 微 命令 ,通常 用 000 表示 不 操作 。 

例如 ,运算 器 的 输出 控制 信号 有 直 传 . 左 移 、 碳 移 、 半 字 交 换 4 个。 这 4 个 微 命令 是 互 斥 
的 。 它 们 可 以 安排 在 同一 字段 编码 内 。 同 样 , 存 储 需 的 读 写 命令 也 是 一 对 互 斥 的 微 命 令 。 
还 有 像 A 一 C、.B 一 C( 假 设 A、B、C 都 是 寄存 器 ) 这 样 一 类 的 微 命 令 也 是 互 斥 的 微 命 令 ,不 人 允 
许 它们 在 同一 时 刻 出 现 。 

假设 某 计 算 机 共有 256 个 微 命 令 ,如 果 采 用 直接 控制 法 , 微 指令 的 操作 控制 字段 就 要 有 
256 位 ;而 如 果 采 用 最 短 编码 法 ,操作 控制 字段 只 需要 8 位 就 可 以 了 。 如 果 采 用 字段 直接 编 
码 法 , 若 4 位 为 一 个 段 ,每 段 可 表示 15 个 互 斥 的 微 命 令 , 则 操作 控制 字段 只 需要 72 位 ,分 成 
18 个 段 ,在 同一 时 刻 可 以 并 行 发 出 18 个 不 同 的 微 命 令 。 

除 上 述 几 种 基本 的 编码 方法 外 ,另外 还 有 一 些 常 见 的 编码 技巧 ,例如 可 采用 微 指令 译 码 
与 部 分 机 器 指令 译 码 的 复合 控制 \ 微 地 址 参与 解释 微 指令 译 码 等 。 对 于 实际 机 器 的 微 指令 
系统 ,通常 同时 采用 几 种 不 同 的 编码 方法 。 例 如 ,在 一 条 微 指 令 中 ,可 以 有 些 位 采用 直接 控 
制 法 ,有些 字段 采用 直接 编码 法 , 另 一 些 字 段 采 用 间接 编码 法 。 总 之 ,要 尽量 减少 微 指令 字 
长 ,增强 微 操作 的 并 行 性 ,提高 机 器 的 控制 性 能 并 降低 成 本 。 


6.4.3 微 程序 控制 器 的 组 成 和 工作 过 程 
1. 微 程序 控制 器 的 基本 组 成 
图 6-13 给 出 了 一 个 微 程序 控制 器 基本 结构 的 简化 框图 ,在 图 中 主要 夯 出 了 微 程序 控制 


人 稻 比 组 合 逻辑 控制 部 多 出 的 部 件 ,包括 控制 存储 大、 微 微 命 令 
指令 寄存 融 、 微 地 址 形成 部 件 和 微 地 址 寄存 融 等 。 [ 


(1) 控制 存储 右 (CM) i 
这 是 微 程序 控 制 器 的 核心 部 件 , 用 来 存放 微 程序 ， 
其 性 能 (包括 容量 、 速 度 、 可 靠 性 等 ) 与 计算 机 的 性 能 密 
(2) 微 指 令 寄 存 需 (CAIR) 
用 来 存放 从 CM 中 取出 的 微 指 令 , 它 的 位 数 同 微 指 
令 字 长 相等 。 
(3) 微 地 址 形成 部 件 
用 来 产生 初始 微 地 址 和 后 继 微 地 址 ,以 保证 微 指令 
的 连续 执行 。 
(4) 微 地 址 寄存 器 (xMAR) IR 


它 接受 微 地 址 形成 部 件 送 来 的 微 地 址 ,为 在 CM 中 
图 6-13 ” 微 程序 控制 器 的 基本 结构 
该 取 微 指令 做 准备 。 


2. 微 程 序 控制 器 的 工作 过 程 
微 程 序 控制 器 的 工作 过 程 实际 上 就 是 在 微 程序 控制 大 的 控制 下 计算 机 运行 机 需 指 令 的 


顺序 控制 字段 


操作 控制 字段 
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过 程 ,这 个 过 程 可 以 描述 如 下 : 

J 执行 取 指 令 公 共 操 作 。 取 指令 的 公共 操作 通常 由 一 个 取 指 微 程序 来 完成 ,这 个 取 指 
微 程序 也 可 能 仅 由 一 条 微 指令 组 成 。 具 体 的 执行 是 : 在 机 天 开始 运行 时 , 目 动 将 取 指 微 程 
序 的 入 口 微 地 址 送 入 MAR ,并 从 CM 中 读 出 相应 的 微 指令 送 入 pwIR。 微 指令 的 操作 控制 
字段 产生 有 关 的 微 命令 ,用 来 控制 计算 机 实现 取 机 需 指 令 的 公共 操作 。 取 指 微 程 序 的 和 人口 
地 址 一 般 为 CM 的 0 号 单元 , 当 取 指 微 程序 执行 完 后 ,从 主 存 中 取出 的 机 需 指 令 就 已 存 人 指 
令 寄 存 大 中 。 

@ 由 机 如 指 令 的 操作 码 字 段 通过 微 地 址 形成 部 件 产 生 该 机 絮 指 令 所 对 应 的 微 程 序 的 
入 口 地 址 ,并 送 入 uMAR.。 

G) 从 CM 中 逐条 取出 对 应 的 微 指令 并 执行 之 。 

@ 执行 完 对 应 于 一 条 机 融 指 令 的 一 个 人 微 程 序 后 又 回 到 取 指 微 程 序 的 入 口 地 址 ,继续 第 
QD 步 , 以 完成 取 下 一 条 机 如 指令 的 公共 操作 。 

以 上 是 一 条 机 副 指 令 的 运行 过 程 ,如 此 周而复始 ,直到 整个 程序 执行 完毕 为 止 。 


3. 机 器 指令 对 应 的 微 程 序 


通常 ,一 条 机 如 指令 对 应 一 个 人 微 程 序 。 由 于 任何 一 条 机 副 指 令 的 取 指 令 操 作 都 是 相同 
的 ,因此 可 以 将 取 指 令 操 作 抽 出 来 编 成 一 个 独立 的 微 程序 ,这 个 微 程序 只 负责 将 指令 从 主 存 
中 取出 送 至 指令 寄存 器 。 此 外 ,也 可 以 编 出 对 应 间 址 周期 的 微 程序 和 中 断 周 期 的 微 程 序 。 
这 样 ,控制 存储 融 中 的 微 程 序 个 数 应 等 于 指令 系统 中 的 机 融 指 令 数 再 加 上 对 应 取 指 . 间 址 和 
中 断 周 期 等 公用 的 人 微 程 序数 。 硅 指令 系统 中 具有 nn 种 机 禹 指令 , 则 控制 存储 右 中 的 微 程 序 
数 至 少 有 nn 十 1 个 。 


6.4.4 微 程序 入 口 地 址 的 形成 


当 公 用 的 取 指 微 程 序 从 主 存 中 取出 机 需 指 令 之 后 ,由 机 需 指 令 的 操作 码 字段 指出 各 个 
微 程序 的 入 口 地 址 (初始 微 地 址 ) 。 这 是 一 种 多 分 文 ( 或 多 路 转移 ) 的 情况 。 由 机 天 指 令 的 操 
作 码 转换 成 初始 微 地 址 的 方式 主要 有 3 种 。 


1. 一 级 功能 转换 


如 果 机 需 指 令 操 作 码 字段 的 位 数 和 位 置 固 定 , 可 以 直接 使 操作 码 与 人 口 地 址 码 的 部 分 
位 相对 应 。 例 如 , 某 计 算 机 系统 有 16 条 机 器 指令 , 指 
令 操 作 码 由 4 位 二 进 制 数 表示 ,分 别 为 0000、0001， 
…,1111。 现 以 字母 96 表示 操作 码 , 令 微 程序 的 入 口 
地 址 为 011B, 例 如 ,MOV 指令 的 操作 码 为 0000, 则 
MOY 指令 的 微 程序 人 口 地 址 为 000011B; ADD 指令 
的 操作 码 为 0001, 则 ADD 指令 的 微 程序 入 口 地 址 为 
000111B…… 由 此 可 见 , 相 邻 两 个 微 程 序 的 入 口 地 址 
相差 4 个 单元 ,如 图 6-14 所 示 。 也 就 是 说 ,每 个 微 程 
序 最 多 可 以 由 4 条 微 指令 组 成 ,如 果 不 足 4 条 就 让 有 
关 单 元 空闲 着 。 图 6-14 指令 操作 码 与 微 程 序 人 口 地 址 


才 洪 
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2. 二 级 功能 转换 


当 同 类 机 器 指令 的 操作 码 字 段 的 位 数 和 位 置 固定 ,而 不 同类 机 需 指 令 的 操作 码 字 段 的 
位 数 和 位 置 不 固定 时 ,就 不 能 再 采用 一 级 功能 转换 的 方法 。 所 谓 二 级 功能 转换 是 指 第 一 次 
先 按 指令 类 型 标志 转移 ,以 区 分 出 指令 属于 哪 类 ,如 是 单 操 作 数 指令 ,还 是 双 操 作 数 指令 等 。 
因为 每 类 机 器 指令 中 操作 码 字 段 的 位 数 和 位 置 是 固定 的 ,所 以 第 二 次 即 可 按 操作 码 区 分 出 
具体 是 哪 条 指令 ,以 便 找 出 相应 微 程序 的 入 口 微 地 址 。 


3. 通过 PLA 电路 实现 功能 转换 


当 机 副 指令 的 操作 码 位 数 和 位 置 都 不 固定 时 ,可 以 采用 PLA 电路 将 每 条 机 带 指 令 的 操 
作 码 翻译 成 对 应 的 微 程 序 入 口 地 址 。 这 种 方法 对 于 变 长 度 、 变 位 置 的 操作 码 显得 更 有 效 ,而 
且 转 换 速 度 较 快 。 


6.4.5 后 继 微 地 址 的 形成 


找到 初始 微 地 址 之 后 ,可 以 开始 执行 微 程序 ,每 条 微 指令 执行 完毕 都 要 根据 要 求 形 成 后 
继 微 地 址 。 后 继 微 地 址 的 形成 方法 对 微 程序 编制 的 灵活 性 影 啊 很 大 , 它 主 要 有 两 个 基本 类 
型 : 增 量 方式 和 断定 方式 。 


1. 增 量 方式 (顺序 一 转移 型 微 地 址 ) 


这 种 方式 和 机 需 指 令 的 控制 方式 很 类 似 , 它 也 有 顺序 执行 、 转 移 和 转子 之 分 。 顺 序 执行 
时 ,后 继 微 地 址 就 是 现行 微 地 址 加 上 一 个 增 量 (通常 为 “1”) ;转移 或 转子 时 ,由 微 指 令 的 顺序 
控制 字段 产生 转移 微 地 址 。 因 此 ,在 微 程序 控制 硕 中 应 当 有 一 个 微 程 序 计 数 需 (prPC) 。 为 
了 降低 成 本 ,一 般 情况 下 都 是 将 微 地 址 寄存 器 (xxMAR) 改 为 具有 计数 功能 的 寄存 器 ,以 代 
蔡 PC。 

增 量 方式 的 优点 是 简单 ,易于 掌握 ,编制 微 程 序 容 易 , 每 条 机 需 指 令 所 对 应 的 一 段 微 程 
序 一 般 安排 在 CM 的 连续 单元 中 ;其 缺点 是 这 种 方式 不 能 实现 两 路 以 上 的 并 行 微 程序 转 
移 ,因而 不 利于 提高 微 程 序 的 执行 速度 。 


2. 断定 方式 


断定 方式 的 后 继 微 地 址 可 申 微 程序 设计 者 指定 ,或 者 根据 微 指令 所 规定 的 测试 结果 下 
接 决 定 后 继 微 地 址 的 全 部 或 部 分 值 。 

这 是 一 种 直接 给 定 与 测试 断定 相 结 合 的 方式 ,其 顺序 控制 字段 一 般 由 两 部 分 组 成 : 非 
测试 段 和 测试 段 。 

J 非 测试 段 : 可 由 设计 者 指定 ,一般 是 微 地 址 的 高 位 部 分 ,用 来 指定 后 继 微 地 址 在 CM 
中 的 茶 个 区 域内 。 

区 测试 段 : 根据 有 关 状 态 的 测试 结果 确定 其 地 址 值 ,一 般 对 应 微 地 址 的 低位 部 分 。 这 
相当 于 在 指定 区 域内 断定 具体 的 分 支 。 所 依据 的 测试 状态 可 能 是 指定 的 开关 状态 、 指 令 操 
作 码 和 状态 字 等 。 

测试 段 如 果 只 有 一 位 , 则 微 地址 将 产生 2 个 分 文 ; 奋 有 两 位 , 则 最 多 可 产生 4 个 分 文 ; 以 


此 类 推 ,测试 段 为 n 位 最 多 可 产生 2 个 分 文 。 
断定 方式 的 优点 是 实现 多 路 并 行 转移 容易 ,有 利于 提高 微 程序 的 执行 效率 和 执行 速度 ， 
且 微 程序 在 CM 中 不 要 求 必须 连续 存放 ;其 缺点 是 后 继 微 地 址 的 生成 机 构 比 较 复 杂 。 


6.4.6 微 程 序 设计 
1. 微 程序 设计 方法 


在 实际 进行 微 程 序 设计 时 ,应 考虑 尽量 缩短 微 指令 字 长 ,减少 微 程序 长 度 , 提 高 微 程序 
的 执行 速度 。 这 几 项 指标 是 互相 制约 的 ,应 当 全 面 地 进行 分 析 和 权衡 。 

(1) 水 平 型 微 指 令 及 水 平 型 微 程序 设计 

水 平 型 微 指 令 是 指 一 次 能 定义 并 能 并 行 执行 多 个 微 命令 的 微 指令 。 它 的 并 行 操作 能 力 
强 ,效率 高 ,灵活 性 强 , 执 行 一 条 机 器 指令 所 需 微 指令 的 数目 少 ,执行 时 间 短 ;但 是 , 微 指令 字 
较 长 ,增加 了 控 存 的 横向 容量 ,同时 微 指令 和 机 器 指令 的 差别 很 大 ,设计 者 只 有 熟悉 了 数据 
通路 , 才 有 可 能 编制 出 理想 的 微 程序 ,一 般 用 户 不 易 掌 握 。 由 于 水 平 型 微 程序 设计 是 面 对 微 
处 理 需 内 部 逻辑 控制 的 描述 ,所 以 把 这 种 微 程序 设计 方法 称 为 硬 方法 。 

(2) 垂直 型 微 指 令 及 垂直 型 微 程序 设计 

垂直 型 微 指令 是 指 一 次 只 能 执行 一 个 微 命令 的 微 指令 。 它 的 并 行 操作 能 力 差 , 一 般 只 
能 实现 一 个 微 操作 ,控制 一 两 个 信息 传送 通路 ,效率 低 , 执 行 一 条 机 器 指令 所 需 的 微 指 令 数 
目 多 ,执行 时 间 长 :但 是 , 微 指令 与 机 器 指令 很 相似 ,所 以 容易 掌握 和 利用 ,编程 比较 简单 ,不 
必 过 多 地 了 解数 据 通路 的 细节 , 且 微 指令 字 较 短 。 由 于 垂直 型 微 程序 设计 是 面向 算法 的 描 
述 , 所 以 把 这 种 微 程序 设计 方法 称 为 软 方法 。 

(3) 混合 型 微 指令 

综合 上 述 两 者 特点 的 微 指 令 称 为 混合 型 微 指令 , 它 上 具有 不 太 长 的 微 指令 字 , 又 具有 一 定 
的 并 行 控制 能 力 ,可 高 效 地 实现 机 器 的 指令 系统 。 


2. 微 指令 的 运行 方式 


运行 一 条 微 指 令 的 过 程 与 运行 机 器 指令 的 过 程 很 类 似 。 第 一 步 将 微 指 令 从 控 存 中 取 
出 , 称 为 取 微 指令 ;对 于 垂直 型 微 指 令 ,还 应 包括 微 操 作 码 的 详 码 时 间 。 第 二 步 执行 微 指令 
所 规定 的 各 个 操作 。 微 指令 的 运行 方式 可 分 为 串 行 和 并 行 两 种 方式 。 

(1) 串 行 方 式 

在 这 种 方式 里 , 取 微 指令 和 执行 微 指令 是 顺序 进行 的 ,在 一 条 微 指令 取出 并 执行 之 后 ， 
才能 取 下 一 条 微 指 令 。 图 6-15 是 微 指令 串 行 运行 方式 的 时 友 图 。 

一 个 微 周 期 里 ,在 取 微 指令 阶段 ,CM 工作 ,数据 通路 等 待 ;而 在 执行 微 指令 阶段 ,CM 
空闲 ,数据 通路 工作 。 

串 行 方式 的 微 周期 较 长 ,但 控制 简单 ,形成 后 继 微 地 址 所 用 的 硬件 设备 较 少 。 

(2) 并 行 方式 

为 了 提高 微 指 令 的 执行 速度 ,可 以 将 取 微 指 令 和 执行 微 指令 的 操作 重 全 起 来 ,从 而 
缩短 微 周 期 。 因 为 这 两 个 操作 是 在 两 个 完全 不 同 的 部 件 中 执行 的 ,所 以 这 种 重生 是 完全 
可 行 的 。 
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短 周 期 1 做 周期 2 
取 微 指令 1， 执行 微 指令 1 | 取 微 指令 2， 执 行 微 指令 2 


首 执 行 结 未 | ] ] 


图 6-15” 微 指令 的 串 行 运 行 方 式 时序 图 


在 执行 本 条 微 指令 的 同时 , 预 取 下 一 条 微 指 令 。 假 设 取 微 指 令 的 时 间 比 执行 微 指令 的 
时 间 短 ,就 以 较 长 的 执行 时 间作 为 微 周期 ,并 行 方式 的 时 序 如 图 6-16 所 示 。 
取 微 指令 1 执行 微 指 令 ] 
取 微 指令 2| 执行 微 指令 2 
所 指 令 3 执行 做 扣 人 3 | 
置 LMAR 
启动 CM | | | | 国 
微 措 令 一 IR ] ] ] ] | 
置 执行 结果 ] | | 


图 6-16 微 指 令 的 并 行 运行 方式 时 序 图 


由 于 执行 本 条 微 指 令 与 预 取 下 一 条 微 指令 是 同时 进行 的 , 硅 遇 到 某 些 需 要 根据 本 条 微 
指令 处 理 结果 而 进行 条 件 转移 的 微 指令 ,就 不 能 并 行 地 取出 来 。 最 简单 的 办 法 就 是 延迟 一 
个 微 周期 再 取 微 指令 。 

除 以 上 两 种 控制 方式 外 ,还 有 串 并行 混合 方式 , 即 当 待 执行 的 微 指令 地 址 与 现行 微 指 
令 处 理 无 关 时 ,采用 并 行 方 式 ; 当 其 受 现行 微 指 令 操作 结果 影响 时 , 则 采用 串 行 方 式 。 


3。 微 程序 仿真 


所 谓 微 程序 仿真 ,一般 是 指 用 一 台 计 算 机 的 微 程 序 去 模仿 另 一 台 计 算 机 的 指令 系统 ,使 
本 来 不 兼容 的 计算 机 之 间 具 有 程序 兼容 的 能 力 。 用 来 进行 仿真 的 计算 机 称 为 簿 主机 ,被 仿 
真 的 计算 机 称 为 目标 机 。 
假设 Mi 为 宿主 机 ,M; 为 目标 机 ,在 Mi 机 上 要 能 使 用 M; 的 机 器 语言 编制 程序 并 执行 ， 
就 有 要求 Mi 的 主 存储 融和 控制 存储 带 中 除 含有 Mi 的 有 关 程 序 外 ,还 要 包含 M: 的 有 关 程 序 ， 
期 图 617 所 未 。 宿主 机 主 存储 器 ”宿主 机 控制 存储 器 
M 提 估 两 种 工作 方式 ,本 机 方式 和 仿 其 方式 。 二 机 二 
在 本 机 方式 时 , M 通过 本 机 微 程 序 解释 执行 本 机 的 微 程序 
的 程序 ;在 仿真 方式 时 ,M 通过 仿真 微 程序 解释 执 解释 目标 机 指令 
i 
2 


行 M; 的 程序 。 仿真 支持 软件 
图 6-17 系统 仿真 时 宿主 机 的 主 存 和 控 存 


4. 动态 微 程 序 设计 


通常 ,对 应 于 一 台 计 算 机 的 指令 系统 有 一 系列 固定 的 微 程 序 。 当 人 微 程序 设计 好 之 后 ,一 
般 不 允许 改变 而 且 也 不 便于 改变 ,这 样 的 设计 叫做 静态 微 程序 设计 。 帮 一 台 计 算 机 能 根据 
不 同 应 用 目标 的 要 求 改变 微 程序 , 则 这 人 台 计 算 机 就 具有 动态 微 程序 设计 功能 。 

动态 微 程序 设计 的 出 发 点 是 为 了 使 计算 机 能 更 灵活 、 更 有 效 地 适应 于 各 种 不 同 的 应 用 
目标 。 例 如 ,在 不 改变 便 件 结构 的 前 提 下 ,如 果 计 算 机 配备 了 两 套 可 供 切 换 的 微 程 序 , 一 套 
是 用 来 实现 科学 计算 的 指令 系统 , 男 一 套 是 用 来 实现 数据 人 处理 的 指令 系统 ,这 样 该 计算 机 就 
能 根据 不 同 的 应 用 需要 随时 改变 和 切换 相应 的 微 程 序 , 以 保证 高 效率 地 实现 科学 计算 或 数 
据 处 理 。 

动态 微 程序 设计 需要 可 写 控制 存储 器 (WCS) 的 支持 ,否则 难以 改变 微 程 序 的 内 容 。 由 
于 动态 微 程序 设计 要 求 对 计算 机 的 结构 和 组 成 非常 熟悉 ,所 以 这 类 改变 微 程序 的 方案 也 是 
由 计算 机 的 设计 人 员 实 现 的 。 


5. 用 户 微 程序 设计 


用 户 微 程 序 设 计 是 指 用 户 可 借助 于 可 写 控制 存储 需 进 行 微 程序 设计 ,通过 本 机 指令 系 
统 中 保留 的 供 扩 充 指 令 用 的 操作 码 或 未 定义 的 操作 码 , 来 定义 用 户 扩充 指令 ,然后 编写 扩充 
指令 的 微 程序 ,并 存 人 可 写 控 存 。 这 样 用 户 可 以 如 同 使 用 本 机 原来 的 指令 一 样 去 使 用 扩充 
指令 ,从 而 大 大 提高 计算 机 系统 的 灵活 性 和 适应 性 。 但 是 ,事实 上 真正 由 用 户 来 编写 微 程序 
是 很 困难 的 。 


6.5 控制 单元 的 设计 


前 面 几 节 介绍 了 控制 器 的 基本 功能 和 CPU 的 总 体 结 构 , 为 了 加 深 对 这 些 内 容 的 理解 ， 
这 市 将 以 一 个 人 简单 的 CPU 为 例 来 讨论 控制 部 中 控制 单元 的 设计 。 为 了 突出 重点 ,减少 篇 
幅 , 故 选择 的 CPU 模型 比较 简单 ,指令 系统 中 仅 具 有 最 第 见 的 基本 指令 和 寻 址 方式 ,在 多 
辑 结 构 . 时 序 安 排 、. 操 作 过 程 安 排 等 方面 尽量 规整 、 简 单 ,使 初学 者 比较 容易 掌握 ,以 帮助 大 
家 建立 整 机 概念 。 


6.5.1 简单 的 CPU 模型 


控制 单元 的 主要 功能 是 根据 需要 发 出 各 种 不 同 的 微 操 作 控 制 信号 。 微 操作 控制 信 
号 是 与 CPU 的 数据 通路 密切 相关 的 ,图 6-18 给 出 了 一 个 单 累 加 器 结构 的 简单 CPU 
模型 。 

图 6-18 中 MAR 和 MDR 分 别 直接 与 地 址 总 线 和 数据 总 线 相 连 。 考 虑 到 从 存储 器 取出 
的 指令 或 有 效 地 址 都 先 送 至 MDR 再 送 至 IR, 故 这 里 省 去 IR 送 至 MAR 的 数据 通路 ,凡是 
需 从 IR 送 至 MAR 的 操作 均 由 MDR 送 至 MAR 代替 。 

计算 机 中 有 一 运行 标志 触发 器 G, 当 G=1 时 ,表示 机 器 运行 ; 当 G=0 时 ,表示 停机 。 

这 个 CPU 的 指令 系统 中 包含 下 列 指令 。 
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主 存 CPU 


6-18 一 个 简单 的 CPU 模型 


1. 非 访 存 指令 


非 访 存 指令 在 执行 周期 不 访问 存储 天 。 

(1) 清除 累加 器 指令 CLA 

该 指令 完成 清除 累加 器 操作 , 记 作 0 一 AC。 

(2) 累加 器 取 反 指令 COM 

该 指令 完成 累加 器 内 容 取 反 ,结果 送 累 加 器 的 操作 , 记 作 (AC) 一 AC。 

(3) 累加 器 加 1 指令 INC 

该 指令 完成 累加 需 内 容 十 1, 结 果 送 累加 需 的 操作 , 记 作 (AC) 十 1 一 AC。 

(4) 算术 右 移 一 位 指令 SHR 

该 指令 完成 累加 费 内 容 算 术 右 移 一 位 的 操作 , 记 作 RCIAC) 一 AC,ACo 一 AC 。 

(5) 循环 左 移 一 位 指令 CSL 

该 指令 完成 累加 费 内 容 循 环 左 移 一 位 的 操作 , 记 作 L(AC) 一 AC,ACo 一 AC,。 

(6) 停机 指令 STP 

将 运行 标志 触发 器 置 “0”, 记 作 0 一 G。 

注意 : 累加 寄存 器 AC 共 n 十 1 位 ,其 中 ACo 为 最 高 位 (符号 位 ) ,AC, 为 最 低位 。ACo 一 
ACo 表 示 算 术 右 移 时 符号 位 保持 不 变 。 


2. 访 存 指令 


访 存 指令 在 执行 周期 需 访问 主 存储 器 。 

(1) 加 法 指令 ADD 

该 指令 完成 累加 器 内 容 与 对 应 主 存 单元 的 内 容 相 加 ,结果 送 累 加 器 的 操作 , 记 作 
(AC) 十 (MDR) 一 AC。 

(2) 减法 指令 SUB 

该 指令 完成 累加 器 内 容 与 对 应 主 存 单元 的 内 容 相 减 , 结 果 送 累加 器 的 操作 , 记 作 
(AC) 一 (MDR) 一 AC。 

(3) 与 指令 AND 

该 指令 完成 累加 器 内 容 与 对 应 主 存单 元 的 内 容 相 与 ,结果 送 累 加 器 的 操作 , 记 作 


记 风 处 理 器 


(AC) 人 A(MDR) 一 AC。 
(4) 取 数 指令 LDA 
该 指令 将 对 应 主 存 单元 的 内 容 取 至 累加 需 中 , 记 作 (MDR) 一 AC。 
(5) 存 数 指令 STA 
该 指令 将 累加 器 的 内 容 存 于 对 应 主 存单 元 中 , 记 作 (AC) 一 MDR。 


3. 转移 指令 


转移 指令 在 执行 周期 也 不 访问 主 存储 大 。 

(1) 无 条 件 转移 指令 JMP 

该 指令 完成 将 指令 的 地 址 码 部 分 ( 即 转移 地 址 ) 送 至 PC 的 操作 , 记 作 (MDR) 一 PC。 

(2) 去 转 移 指 令 JZ 

该 指令 根据 上 一 条 指令 运行 的 结果 决定 下 一 条 指令 的 地 址 , 奋 运 算 结果 为 零 ( 标 志 位 
Z 二 1), 则 指令 的 地 址 码 部 分 ( 即 转 移 地 址 ) 送 至 PC, 和 否则 程序 按 原 顺 序 执行 。 由 于 在 取 指 
阶段 已 完成 了 (PC) 十 1 一 PC, 所 以 当 运 算 结果 不 为 零 时 ,就 按 取 指 阶段 形成 的 PC 执行 , 记 
作 Z， (MDR) 二 Z， (PC) 一 PC。 

(3) 负 转 移 指令 JN 

和 藻 结 果 为 负 ( 标 志 位 N==1), 则 指令 的 地 址 码 部 分 送 至 PC ,否则 程序 按 原 顺 序 执行 。 记 
作 N。(MDR) 十 N。(PC)- 一 PC。 

(4) 进位 转移 指令 JC 

若 结 果 有 进位 (标志 位 C=1), 则 指令 的 地 址 码 部 分 送 至 PC, 和 否则 程序 按 原 顺 序 执行 。 
记 作 C。(MDR) 十 C。(PC)- 一 PC。 

上 述 3 类 指令 的 指令 周期 如 图 6-19 所 示 ,其 中 访 存 指令 又 被 细 分 为 直接 访 存 和 间接 访 
存 两 种 。 


非 访 仓 | 。 取 指 周期 。| 。 执行 周期 。 
指令 周期 取 指 周期 执行 周期 
直接 访 存 | 。 取 指 周期 执行 周期 

日 令 周 期 


间接 访 存 | 取 指 周期 间 址 周期 执行 周期 
指令 周期 


转移 忆 忆 二 
取 指 周期 执行 周期 | 


6-19 3 类 指令 的 指令 周期 


在 简单 的 CPU 模型 中 ,把 一 个 完整 的 指令 周期 分 为 取 指 、 间 址 ,执行 和 中 断 4 个 机 需 周 
期 。 这 4 个 机 需 周 期 中 都 有 CPU 访 存 操作 ,只 是 访 存 的 目的 不 同 。 取 指 周 期 是 为 了 取 指 
令 , 间 址 周期 是 为 了 取 有 效 地 址 ,执行 周期 是 为 了 取 操 作 数 ( 当 指令 为 访 存 指令 时 ) ,中 断 周 
期 是 为 了 保存 程序 断 点 。 这 4 个 周期 又 可 称 为 CPU 工作 周期 ,为 了 区 别 它 们 ,在 CPU 内 可 
设置 4 个 标志 触发 需 , 如 图 6-20 所 示 。 哪 个 触发 需 处 于 "12 状态 ,就 表示 机 需 正 处 于 哪个 周 
期 运行 。 因 此 ,同一 时 刻 有 一 个 且 仅 有 一 个 触发 器 处 于 "1? 状 态 。 

图 6-20 所 示 的 FEJIND、EX 和 INT 分 别 对 应 取 指 、 间 址 .执行 和 中 断 4 个 周期 ,它们 分 
别 由 1~FE、1~>IND、1~EX 和 1-~>INT4 个 信号 控制 。 


坟 吕 加 
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CLK 


1—FE I~IND 1 一 EX I~INT 
图 6-20 CPU 工作 周期 的 标志 


6.5.2 组 合 逻 和 辑 控制 单元 设计 
1. 微 操作 的 节拍 安排 


假设 机 器 采用 同步 控制 ,每 个 机 器 周期 包括 3 个 节拍 ,安排 微 操 作 节 拍 时 应 注意 以 下 几 点 : 

J 有 些微 操作 的 次 序 是 不 容 改变 的 , 故 安 排 微 操 作 节 拍 时 必须 注意 微 操 作 的 先后 顺序 。 

@ 凡是 被 控制 对 象 不 同 的 微 操 作 , 奉 能 在 一 个 节拍 内 执行 ,应 尽 可 能 安排 在 同一 个 节 
拍 内 ,以 节省 时 间 。 

(3) 如 果 有 些微 操作 所 占 的 时 间 不 长 ,应 该 将 它们 安排 在 一 个 节拍 内 完成 ,并 且 人 允许 这 
些微 操作 有 先后 次 序 。 

(1) 取 指 周期 微 操 作 的 节拍 安排 

取 指 周期 的 操作 是 公 操 作 , 其 完成 的 任务 已 在 前 面 进行 过 描述 ,在 此 不 再 重复 ,这 些 操 


作 可 以 安排 在 3 个 节拍 中 完成 。 
To (PC)—>MAR, Read 
Ti MCMAR) 一 MDR ,(PC) 十 1-PC 
T， (MDR)—™>IR 


考虑 到 指令 译 码 时 间 较 短 ,可 将 指令 译 码 OP(IR) 习 ID 也 安排 在 T; 节 拍 内 。 

(2) 间 址 周期 微 操 作 的 节 提 安排 

间 址 周期 完成 取 操作 数 有 效 地 址 的 任务 ,具体 操作 如 下 : 

Q 将 指令 的 地 址 码 部 分 (形式 地 址 ) 送 至 存储 大 地 址 寄存 需 , 记 作 C(MDR) 一 MAR。 

色 回 主 存 发 谈 命 令 ,启动 主 存 读 操作 , 记 作 Read。 

3 将 MAR 所 指 的 主 存 单元 中 的 内 容 ( 有 效 地 址 ) 经 数据 总 线 读 至 MDR, 记 作 
M(MAR)— MDR. 

@ 将 有 效 地 址 送 至 存储 器 地 址 寄存 器 (MAR), 记 作 (MDR) 一 MAR。 此 操作 在 有 些 机 


入 中 可 省 略 。 
这 些 操作 可 以 安排 在 以 下 3 个 节拍 中 完成 : 
Is (MDR)—MAR., Read 
Ti M(MAR)— MDR 
T, (MDR)—MAR 


(3) 执行 周期 微 操 作 的 节拍 安排 

| 非 访 存 指令 。 

非 访 存 指令 在 执行 周期 只 有 一 个 微 操作 , 按 同 步 控制 的 原则 ,此 操作 可 安排 在 Te 一 T 
的 任 一 节拍 内 ,其 余 节 拍 空 。 

。 清 零 指 令 CLA: 


工 
通 
T， 0 一 AC 
。 取 反 指令 COM 
1o 
工 
(AC) 一 AC 
。 加 1 指令 INC 
1o 
工 
Ts (AC)+1—>AC 
。 算 木 右 移 指 令 SHR: 
工 
上 
到 RCAC) 一 AC,ACo 一 AC。 
e。 循环 左 移 指令 CSL: 
工 
工 
下 LCAC) 一 AC,ACo 一 AC， 
。 停机 指令 STP: 
1o 
工 
0 一 G 
@O) 访 存 指令 。 
。 加 法 指令 ADD X: 
TT (MDR)—MAR, Read 
T， M(MAR)— MDR 
(AC) 十 (MDR) 一 AC( 该 操作 实际 包括 (AC) 一 ALU, (MDR) 一 ALU， 
十 ,ALUAC) 
。 减法 指令 SUB X: 
人 (MDR)—MAR, Read 
M(MAR)— MDR 
Ts (AC)— (MDR)—AC 
。 与 指令 AND X: 
有 (MDR ) 一 MAR ,Read 
加 M(MAR)— MDR 
jy (AC) A (MDR)—AC 


。 取 数 指令 LDA X. 
Te (MDR)—>MAR, Read 
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T, M(MAR)— MDR 
下 (MDR)—>AC 

。 存 数 指令 STA X: 
y (MDR )- 一 MAR 
T， (AC) 一 MDR , Write 
下 MDR->MCMAR) 


QB 转移 类 指令 。 
。 无 条 件 转移 JMP X: 


1 。 

Ti 

FT. (MDR)—>PC 
。 结果 为 去 转 JZ X: 

1o 

工 

开 Z. (MDR)+Z. (PC)—>PC 
® 结果 有 进位 转 JC X: 

工 

工 

C。(MDR) 二 C。(PC) 一 PC 
。 结果 为 负 转 JN X: 

To 

Ti 

T, N。(MDR) 二 N。(PC) 一 PC 


2. 组 合 逻 辑 设计 步骤 


组 合 逻 辑 设计 控制 单元 时 ,首先 根据 上 述 微 操作 的 节拍 安排 , 列 出 微 操作 命令 的 操作 时 
间 表 ,然后 写 出 每 一 个 微 操作 命令 (控制 信和 号) 的 逻辑 表达 式 , 最 后 根据 逻辑 表达 式 画 出 相应 
的 组 合 逻辑 电路 网 。 

(1) 列 出 微 操作 命令 的 操作 时 间 表 

表 6-1 列 出 了 上 述 各 条 机 融 指 令 的 微 操作 控制 信号 的 操作 时 间 表 。 表 中 FE、IND 和 
EX 为 CPU 工作 周期 标志 ,T, 一 T; 为 节拍 ,I 为 则 址 标志 ,在 取 指 周期 的 T; 时 刻 , 硅 测 得 I= 
1, 则 置 “1”IND 触发 颖 ,进入 间 址 周期 ; 夺 I 二 0, 则 置 “1”EX 触发 硕 ,进入 执行 周期 。 同 理 ， 
在 间 址 周期 的 TT; 时 刻 , 告 测 得 IND=0( 表 示 一 次 间 址 ) , 则 置 “1”EX, 进 入 执行 周期 ; 耕 测 得 
IND=1( 表 示 多 次 间 址 ) , 则 继续 间接 寻 址 。 在 执行 周期 的 T; 时 刻 如 果 没 有 中 断 请 求 , 则 置 
“12?FE ,进入 下 一 条 指令 的 取 指 周期 。 为 简单 起 见 , 表 中 空格 中 “0 默认 未 画 出 。 

(2) 进行 微 操 作 信 号 综合 

在 列 出 微 操作 时 间 表 之 后 , 即 可 对 它们 进行 综合 分 析 、 归 类 ,根据 微 操 作 时 间 表 可 以 写 
出 各 微 操作 控制 信号 的 逻辑 表达 式 。 表 达 式 一 般 包 括 下 列 因素 . 

微 操 作 控 制 信号 二 机 器 周期 人 节拍 人 脉冲 人 操作 码 信 机 器 状态 条 件 


-| 


因 央 处 理 器 


天 天天 天 一 Dd 一 QIGNDPV 
Dd 一 CIGADPV 


9 
2 
aIAIWDPVY 
| 0 
JDY< (DY) 
二 ee 
IV<(IYV)Y 
| DVI+GOV) 
| | VY OW 
扣 计 是 诸 Te 
VQaWN) 
(IVN)IN<- (IWN) 
JDV<CJJIN) V (CDV) 
JDV< (HIN) — (VV) 


DOV<-(IQWN)++ (IV) 


TT | | | S40)| | 
LI Dd<QGAPV| N 
攻 


并 并 十 十 二 十 十 二 二 二 一 一 
TT I | I | INAVION 
i 
EE 


举国 册 拨 启 名 ”1-9 举 


| || WVIDOWN 
CT EN 
CT NOV) 
| | Peey 
| IVN QW 
TT TT TT TIT|I| | | | | | | X34<I1| dN 
DTT VAQWDD | < 再 图 ) 
LI TLTTTTT NAVWDA| Gen 
I 一 一 一 一 
LILILTLI TITTLTTTTTT VN QW 
TUTTI | XI<IT| I 
TANI<IT| I |, 
[ 于 
UTI | UW ( 辟 痊 ) 
[ 
I 
I 
[ 
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例如 ,根据 微 操 作 时 间 表 写 出 M(MAR) 一 MDR 逻辑 表达 式 ,并 进行 适当 的 简化 : 
M(MAR)— MDR 
=FE. T+IND. T,(ADD+SUB+AND+LDA+STA+JMP+JZ+JC+JN) 
十 EX.。 Ti(ADD++SUB 二 AND 二 LDA) 
=T){FE+IND(ADD+SUB+AND++LDA+STA+JMP++JZ+JC+JN) 
+EX(ADD+SUB+ AND+LDA)} 
式 中 ADD、SUB 等 均 来 和 目 操作 码 译 码 需 的 输出 。 
(3) 男 出 微 操 作 命令 的 逻辑 图 
根据 逻辑 表达 式 可 画 出 对 应 每 一 个 微 操作 控制 信号 的 逻辑 电路 图 ,并 用 逻辑 门 电 路 实 
现 之 。 


6.5.3 微 程序 控制 单元 设计 
微 程序 设计 控制 单元 的 主要 任务 是 编写 对 应 各 条 机 器 指令 的 微 程 序 , 具 体 步 骤 是 首先 


写 出 对 应 机 硕 指令 的 全 部 微 操 作 节 担 安 排 ,然后 确定 微 指令 格式 ,最 后 编写 出 每 条 微 指令 的 
二 进 制 代码 。 


1. 微 程 序 控制 单元 的 设计 步骤 


(1) 确定 微 程序 控制 方式 

根据 计算 机 系统 的 性 能 指标 (主要 是 速度 ) 确 定 微 程序 控制 方式 。 如 是 采用 水 平 微 程 序 
设计 还 是 采用 垂直 微 程序 设计 , 微 指令 是 按 弟 行 方式 运行 还 是 按 并 行 方 式 运行 等 。 

(2) 拟定 微 命 令 系 统 

初步 拟定 微 命 令 系 统 , 并 同时 进行 微 指 令 格式 的 设计 ,包括 微 指令 字段 的 划分 、 编 码 方 
式 的 选择 .初始 微 地 址 和 后 继 微 地 址 的 形成 等 。 

(3) 编制 微 程 序 

对 微 命令 系统 、 微 指令 格式 进行 反复 的 核对 和 审查 ,并 进行 适当 的 修改 ;对 重复 和 多 余 
的 微 指令 进行 合并 和 精简 ,直至 编制 出 全 部 机 器 指令 的 微 程序 为 止 。 

(4) 微 程 序 代 码 化 

将 修改 完善 的 微 程序 转换 成 二 进 制 代码 ,这 一 过 程 称 为 代码 化 或 代 真 。 代 真 工作 可 以 
用 人 工 实现 ,也 可 以 在 机 器 上 用 程序 实现 。 

(5) 写 入 控制 存储 器 

最 后 将 一 串 串 二 进 制 代 码 按 地 址 写 入 控制 存储 器 的 对 应 单元 。 


2. 设计 举例 

为 了 便于 与 组 合 逻辑 设计 比较 , 仍 以 前 述 的 15 条 机 器 指令 为 例 , 而 且 假 设 CPU 结构 与 
组 合 逻 辑 设计 相同 。 为 简化 起 见 , 不 考虑 间接 寻 址 的 情况 。 

由 于 微 命 令 的 数目 不 多 , 故 采 用 直接 控制 方式 , 即 微 指令 控制 字段 的 每 一 位 直接 控制 一 
个 微 操 作 。 微 程序 的 后 继 微 地 址 的 形成 方法 采用 增 量 方式 ,在 微 指 令 中 不 设 顺 序 控制 字段 。 


每 执行 一 条 微 指令 ,wxMAR 自动 加 1。 

取 指 微 程序 的 入 口 地 址 是 控 存 的 00H 单元 ,机 器 启动 后 ,wxMAR 自动 指向 00H 单元 。 
取 指 微 程 序 从 主 存 中 取出 一 条 机 器 指令 送 入 IR ,再 根据 机 器 指令 的 操作 码 变换 成 相应 的 微 
程序 入口 地 址 ,实现 一 级 功能 转移 。 

当 一 条 机 器 指令 执行 完毕 后 ,应 当 转 去 执行 下 一 条 机 器 指令 ,即使 该 机 器 指令 对 应 的 微 
程序 的 最 后 一 条 微 指令 执行 完 后 转向 取 指 微 程序 。 为 了 简化 设计 ,在 微 指 令 中 专门 设置 了 
一 个 机 器 指令 执行 完 的 标志 。 每 一 条 机 器 指令 的 最 后 一 条 微 指令 中 令 该 位 为 “1”, 当 执行 到 
这 条 微 指令 时 ,使 AMAR 清 0, 指 向 控 存 中 取 指 微 程序 的 人口 地 址 ,下 一 条 要 执行 的 就 是 取 
指 微 指令 了 。 

本 系统 总 共 需 要 25 个 微 命令 ,其 中 : 

第 0 位 (PC) 一 MAR 

第 1 位 Read 

第 2 位 M(MAR) 一 MDR 

第 3 位 (PC) 十 1 一 PC 

第 4 位 (MDR) 一 IR 

第 5 位 0 一 AC 

第 6 位 (AC) 一 AC 

第 7 位 (AC) 十 1 一 AC 

第 8 位 RC(AC) 一 AC,AC, 一 AC, 

第 9 位 LICAC) 一 AC,ACo 一 AC， 

第 10 位 0 一 G 

第 11 位 (MDR) 一 MAR 

第 12 位 (AC) 十 (MDR) 一 AC 

第 13 位 (AC) 一 (MDR) 一 AC 

第 14 位 (AC) A (MDR) 一 AC 

第 15 位 (MDR) 一 AC 

第 16 位 (AC) 一 MDR 

第 17 位 Write 

第 18 位 MDR 一 M(MAR) 

第 19 位 (MDR) 一 PC 

第 20 位 Z。 (MDR) 十 Z.(PC) 一 PC 

第 21 位 C。(MDR) 二 C。(PC)- 一 PC 

第 22 位 N。(MDR) 十 N。(PC) 一 PC 

第 23 位 微 指令 转移 标志 ,该 位 =0, 转 取 指 微 程序 的 入口 地 址 (0 号 单元 ) 或 转 各 机 需 指 
令 微 程序 的 入 口 地 址 (操作 码 字 段 后 加 11 得 到 ) ;该 位 =1, 微 指令 顺序 执行 。 

第 24 位 一 条 机 需 指 令 执行 完 标 志 ,该 位 =1, 表 示 该 指令 执行 完 。 

表 6-2 列 出 了 对 应 15 条 机 需 指 令 的 微 指令 码 点 。 
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表 6-2 微 指 令 码 点 
微 指 令 ( 二 进 制 代 码 ) 


加 四 HHA 


00H 0 1101010 
取 指 |0IH |010111110 
[3 0 | 0 
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6.6 流水 线 技 术 


对 于 指令 的 执行 ,可 有 几 种 控制 方式 : 顺序 方式 .重生 方式 .先行 控制 及 流水 线 控制 方 
式 。 顺 序 方式 指 的 是 各 条 机 融 指 令 之 间 顺 序 串 行 的 执行 , 即 执行 完 一 条 指令 后 , 方 可 取出 下 
一 条 指令 来 执行 。 这 种 方式 控制 简单 ,但 速度 慢 ,机 需 各 部 件 的 利用 率 低 。 为 了 加 快 指 令 的 
执行 速度 ,充分 利用 计算 机 系统 的 硬件 资源 ,提高 机 融 的 厨 吐 率 ,计算机 中 第 采用 重生 方式 、 
先行 控制 方式 以 及 流水 线 控制 方式 。 


6.6.1 重合 控制 


通常 ,一 条 指令 的 运行 过 程 可 以 分 为 3 个 阶段 : 取 指 、 分析、 执行 。 假 定 每 个 阶段 所 需 
的 时 间 为 1, 那么 在 无 重生 (顺序 ) 的 情况 下 ,需要 3t 才能 得 到 一 条 指令 的 执行 结果 ,如 
图 6-21(a) 所 示 ,。, 故 采用 顺序 方式 执行 n 条 指令 所 需 的 时 间 为 : 

下 = 
如 宁 每 个 阶段 所 需 时 间 各 为 th 指 \ 远 析 和 i 行 ， 则 顺序 执行 n 条 指令 所 需 时 间 为 : 
T= > 《1 十 雪 析 十 tf 执行 》 

最 早出 现 的 重合 是 “ 取 指 K 十 1” 和 “执行 K” 在 时 间 上 的 重 倒 , 称 为 一 次 香蕉 ,如 图 6-21(b) 

所 示 ,这 将 使 处 理 机 速度 有 所 提高 ,所 需 执行 时 间 减 少 为 : 
T=3Xiti(n—1)X2t= (2Xn 

一 次 重 全 方式 需要 增加 一 个 指令 缓冲 带 , 在 执行 第 KK 条 指令 时 ,寄存 所 取出 的 第 天 十 1 
条 指令 。 如 果 进 一 步 增加 重 倒 ,使 * 取 指 K 十 2”“* 分 析 K 十 1” 和 “执行 K” 重 又 起 来 , 称 为 二 
次 重 登 ( 见 图 6-21(c)), 则 处 理 机 速度 还 可 以 进一步 提高 ,所 需 执 行 时 间 减 少 为 : 

工 王 3Xt 十 (2 一 1 一 (2 二 7) 


K| 取 指 | 分 析 | 执行 | 


K+1| 取 指 | 分 析 | 执行 | 
(a) 


有 | 取 指 | 分析 | 执行 | 
K+1| 取 指 | 分 析 | 执行 | 
(b) 
KK| 取 指 | 分 析 | 执行 | 
K+1| 取 指 | 分析 | 执行 | 
K421 取 指 | 分 析 | 执行 | 
(c) 
图 6-21 重 委 控制 方式 


为 了 能 在 “执行 K” 的 同时 ,完成 “分 析 K 十 1” 和 “ 取 指 K 十 2” 的 工作 ,就 需要 控制 器 同 
时 发 出 3 个 阶段 所 需 的 控制 信和 号。 为 此 ,应 把 CPU 中 原来 集中 的 控制 右 , 分 解 为 存储 控制 
天、 指令 控制 六 和 运算 控制 天 。 

如 果 在 “分 析 K 十 1” 时 需要 访 存 取出 操作 数 , 而 “ 取 指 K 十 2” 时 也 需 访 存 取 指 令 , 此 时 
就 会 出 现 访 存 冲突 。 为 了 解决 这 个 问题 ,第 一 种 方法 是 设置 两 个 存储 天 ,分 别 用 来 存放 操作 
数 和 指令 , 即 采 用 哈佛 结构 。 第 二 种 方法 是 主 存 采用 多 体 交 又 存储 结构 ,指令 和 操作 数 仍 混 
存 于 主 存 中 ,只 要 第 KK 十 1 条 指令 的 操作 数 和 第 K 十 2 条 指令 本 身 不 在 同一 存储 体内 ,就 能 
在 一 个 存储 周期 内 同时 取出 两 者 。 第 三 种 方法 是 设置 指令 缓冲 硕 ( 指 令 预 取 队 列 ) ,预先 将 
未 执行 到 的 下 一 条 指令 由 主 存 中 取 到 指令 缓冲 硕 去 ,这 样 “ 取 指 KK 十 2” 时 只 需 将 第 K 十 2 
条 指令 由 指令 缓冲 需 中 拿 出 来 送 到 指令 寄存 大 去 ,而 无 须 访 问 主 存 了 。 

很 明显 ,指令 的 重合 执行 并 不 能 加 快 单条 指令 的 执行 时 间 , 但 可 以 加 快 相 邻 两 条 、 多 条 
指令 万 至 整个 程序 段 的 执行 时 间 。 
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指令 的 重 有 登 执 行 对 于 大 多 数 非 分 文 程序 来 说 可 以 提高 执行 速度 ;但 如 果 遇 到 转移 、 转 子 
指令 和 各 种 中 断 ,或 者 遇 到 第 K 条 指令 的 执行 结果 正巧 是 第 KK 十 1 条 指令 的 操作 数 的 情况 
(数据 相关 ) 时 ,提前 取出 的 指令 将 是 无 效 的 ,此 时 重 琶 也 就 失败 了 。 


6.6.2 先行 控制 原理 


假设 每 次 都 可 以 在 指令 缓冲 器 中 取得 指令 , 则 取 指 阶段 就 可 合并 到 分 析 阶 段 中 ,指令 的 
运行 过 程 就 变 为 分 析 和 执行 两 个 阶段 了 。 如 果 所 有 指令 的 "分析 ?与 “执行 ?的 时 间 均 相等 ， 
则 重生 的 流程 是 非常 流畅 的 ,机 器 的 指令 分 析 部 件 和 执行 部 件 功能 充分 地 发 挥 ,机 器 的 速度 
也 能 显著 地 提高 。 但 是 ,现代 计算 机 的 指令 系统 很 复杂 ,各 种 类 型 指令 难于 做 到 “分 析 ” 与 
“执行 ?时 间 始 终 相 等 ,此 时 ,各 个 阶段 的 控制 部 件 就 有 可 能 出 现 间断 等 待 的 问题 。 在 
图 6-22 中 ,分析 部 件 在 “分 析 KK 十 1” 和 “分 析 K 十 2” 之 间 有 一 个 等 待 时 间 An ,在 “分 析 KK 十 
2” 和 “分 析 KK 十 3” 之 间 又 有 一 个 等 待 时 间 At; ;执行 部 件 在 “执行 K 十 2” 和 “执行 K 十 3” 之 间 
有 一 个 等 待 时 间 At 。 指 令 的 分 析 部 件 和 执行 部 件 都 不 能 连续 地 流畅 地 工作 ,从 而 使 机 需 
的 整体 速度 受到 影响 


EE 


At> 
| 


图 6-22 “分 析 ” 和 “执行 "时 间 不 等 的 重 和 


由 于 分 析 和 执行 部 件 有 时 处 于 空闲 状态 ,此 时 执行 n 条 指令 所 需 时 间 为 : 
T = ty#i 十 > | max (ft 分析 i ，Z 执 行 i-1) .十 执行 


为 了 使 各 部 件 能 连续 地 工作 ,提出 了 先行 控制 的 方式 ,如 图 6-23 所 示 。 虽 然 图 中 “分 
析 ” 和 ”执行 ?阶段 之 间 有 等 待 的 时 间 间 隔 At; ,但 它们 各 日 的 流程 中 却 是 连续 的 。 先 行 控制 
的 主要 目的 是 使 各 阶段 的 专用 控制 部 件 不 间断 的 工作 ,以 提高 设备 的 利用 率 及 执行 速度 。 


图 6-23 ”先行 控制 方式 的 时 序 


由 于 分 析 和 执行 部 件 能 分 别 连续 不 断 地 分 析 和 执行 指令 ,此 时 执行 于 条 指令 所 需 时 
间 为 : 
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T% 行 一 纷 析 ! 十 谊 二 和 
=] 


6.6.3 流水 工作 原理 


流水 处 理 技术 是 在 重合 、 先 行 控 制 方式 的 基础 上 发 展 起 来 的 , 它 基 于 重合 的 原理 ,但 却 
是 在 更 局 程度 上 的 重合 。 


1. 流水 线 


流水 线 是 将 一 个 较 复杂 的 处 理 过 程 分 成 m 个 复杂 程度 相当 、 处 理 时 间 大 臻 相等 的 子 过 
程 ,每 个 子 过 程 由 一 个 独立 的 功能 部 件 来 完成 ,处 理 对 象 在 各 子 过 程 连 成 的 线路 上 连续 流 
动 。 在 同一 时 间 ,m 个 部 件 同 时 进行 不 同 的 操作 ,完成 对 不 同 对 象 的 处 理 。 这 种 方式 类 似 
于 现代 工矿 的 生产 流水 线 , 在 那里 每 隔 一段 时 间 (Ai) 从 流水 线 上 流出 一 个 产品 ,而 生产 这 
个 产品 的 总 时 间 要 比 At 大 得 多 。 由 于 流水 线 上 
各 部 件 并 行 工作 ,机 器 的 大 吐 率 将 大 大 提高 。 例 “< Eos 
如 ,将 一 条 指令 的 执行 过 程 分 成 取 指令 、 指 令 译 
码 、 取 操作 数 和 执行 4 个 子 过 程 ,分 别 由 4 个 功 
能 部 件 来 完成 ,每 个 子 过 程 所 需 时 间 为 At,4 个 
子 过 程 的 流水 线 如 图 6-24(a) 所 示 。 

图 6-24(b) 是 流水 线 工 作 的 时 空 图 。 图 中 横 
坐标 为 时 间 , 纵 坐 标 为 空间 ( 即 各 子 过 程 ), 标 有 
数字 的 方 格 说 明 占 用 该 空间 与 时 间 的 任务 号 ,在 图 6-24 4 个 子 过 程 的 流水 处 理 
本 例 中 表示 机 天 处 理 的 第 一 、 二 三、 四 条 指令 
最 多 可 以 有 4 条 指令 在 不 同 的 部 件 中 国 时 进行 处 理 . 大 执行 一 条 指令 所 需 时 间 为 本 ,那么 


在 理想 情况 下 , 当 流 水 线 充满 后 ,每 隔 Ar = 二 就 完成 了 一 条 指令 的 执行 。 图 中 子 过 程 数 
7 一 4, 任 务 数 2 一 4。 
2. 流水 线 分 类 


按照 不 同 角度 ,流水 线 可 有 多 种 不 同 分 类 方法 。 

(1) 按 处 理 级 别 分 类 

流水 线 按 处 理 级 别 可 分 为 操作 部 件 级 .指令 级 和 处 理 机 级 3 种 。 操 作 部 件 级 流水 线 是 
将 复杂 的 算术 逻辑 运算 组 成 流水 线 工作 方式 。 例 如 ,可 将 浮 点 加 法 操作 分 成 求 阶 差 .对 阶 、 
尾数 相 加 以 及 结果 规格 化 4 个子 过 程 。 指 令 级 流水 线 则 是 将 指令 的 整个 执行 过 程 分 成 多 个 
子 过 程 ,如 前 面 提 到 的 取 指 令 、 指 令 译 码 、 取 操作 数 和 执行 4 个子 过 程 。 处 理 机 级 流水 线 又 
称 宏 流 水 线 , 如 图 6-25 所 示 , 这 种 流水 线 由 两 个 或 两 个 以 上 处 理 机 通过 存储 器 串 行 连接 起 
来 ,每 个 处 理 机 对 同一 数据 流 的 不 同 部 分 分 别 进行 处 理 。 各 个 处 理 机 的 输出 结果 存放 在 与 
下 一 个 处 理 机 所 共享 的 存储 器 中 。 每 个 处 理 机 完成 某 一 专门 任务 。 

(2) 按 功 能 分 类 

流水 线 按 功 能 可 分 成 单 功能 流水 线 和 多 功能 流水 线 两 种 。 单 功能 流水 线 只 能 实现 一 种 


了 
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任务 2 任务 n 


任务 ] 
图 6-25 ”处理 机 级 流水 线 


固定 的 功能 ,例如 , 浮 点 加 法 流水 线 专门 完成 浮 点 加 法 运算 , 浮 点 乘法 流水 线 专门 完成 浮 点 
乘法 运算 。 多 功能 流水 线 则 可 有 多 种 连接 方式 来 实现 多 种 功能 ,例如 ,美国 TI 公司 生产 的 
ASC 计算 机 中 的 一 个 多 功能 流水 线 , 共 有 8 个 功能 段 ( 见 图 6-26(a)), 按 需要 它 可 将 不 同 的 
功能 段 连接 起 来 完成 某 一 功能 ,以 实现 定点 加 法 ( 见 图 6-26(b))、 浮 点 加 法 ( 见 图 6-26(c)) 
和 定点 乘法 ( 见 图 6-26(d) ) 等 功能 。 
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(a) 
6-26 ”TI-ASC 计算 机 的 多 功能 流水 线 


(3) 按 工 作 方式 分 类 

多 功能 流水 线 按 工 作 方 式 可 分 为 静态 流水 线 和 动态 流水 线 两 种 。 

静态 流水 线 在 同一 时 间 内 各 段 只 能 以 一 种 功能 连接 流水 , 当 从 一 种 功能 连接 变 为 另 一 
种 功能 连接 时 ,必须 先 排 空 流 水 线 , 然 后 为 另 一 种 功能 设置 初始 条 件 后 方 可 使 用 。 显 然 ,不 
希望 这 种 功能 的 转换 频繁 发 生 , 否 则 将 严重 影响 流水 线 的 处 理 效率 。 

动态 流水 线 则 允许 在 同一 时 间 内 将 不 同 的 功能 段 连接 成 不 同 的 功能 子 集 , 以 完成 不 同 
的 功能 。 

(4) 按 流水 线 结构 分 类 

流水 线 按 结构 分 为 线性 流水 线 和 非 线 性 流水 线 两 种 。 在 线性 流水 线 中 ,从 输入 到 输出 ， 
每 个 功能 段 只 允许 经 过 一 次 ,不 存在 反馈 回路 。 一 般 的 流水 线 均 属 这 一 类 。 非 线性 流水 线 
除 有 串 行 连接 通路 外 ,还 有 反馈 回路 ,在 流水 过 程 中 , 某 些 功能 段 要 反复 多 次 使 用 。 


3. 指令 流水 线 的 相关 性 
对 于 指令 流水 线 , 相 邻 或 相近 的 两 条 指令 可 能 会 因为 存在 某 种 关联 ,后 一 条 指令 不 能 按 
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照 原 指定 的 时 钟 周期 运行 ,使 流水 线 断 流 。 指 令 流 水 线 的 相关 性 包括 结构 相关 、 数 据 相 关 、 
控制 相关 。 

(1) 结构 相关 

由 于 多 条 指令 在 同一 时 刻 争夺 同一 资源 而 形成 的 冲突 称 为 结构 相关 ,也 称 资源 相关 。 

(2) 数据 相关 

后 续 指令 要 使 用 前 面 指令 的 操作 结果 ,而 这 一 结果 尚未 产生 或 者 未 送 到 指定 的 位 置 , 从 
而 造成 后 续 指 令 无 法 运行 的 局 面 称 为 数据 相关 。 

根据 指令 间 对 同一 个 寄存 器 读 或 写 操 作 的 先后 次 序 关 系 ,数据 相关 可 分 为 RAW( 写 后 
读 )\WAR( 读 后 写 ) 和 WAW( 写 后 写 )3 种 类 型 。 例 如 ,有 1 和 j 两 条 指令 ,i 指令 在 前 ,j 指 
令 在 后 , 则 3 种 不 同类 型 的 数据 相关 的 含义 如 下 。 

RAW: 指令 j 试图 在 指令 1 写 人 寄存 器 前 就 读 出 该 寄存 右 内 容 , 这 样 指 令 j 就 会 错误 地 
读 出 该 寄存 器 旧 的 内 容 。 

WAR: 指令 j 试图 在 指令 i 读 出 该 寄存 器 前 就 写 和 人 该 寄存 器 ,这 样 指 令 i 就 会 错误 地 读 
出 该 寄存 器 的 新 内 容 。 

WAW: 指令 j 试图 在 指令 1 写 入 寄存 右前 就 写 和 人 该 寄存 器 ,这 样 两 次 写 的 先后 次 序 被 
颠倒 ,就 会 错误 地 使 由 指令 ii 写 和 人 的 值 成 为 该 寄存 器 的 内 容 。 

上 述 的 3 种 数据 相关 ,在 按 序 流动 的 流水 线 中 ,只 可 能 出 现 RAW 相关 ;在 非 按 序 流动 
的 流水 线 中 , 既 可 能 发 生 RAW 相关 ,也 可 能 发 生 WAR 和 WAW 相关 。 

(3) 控制 相关 

控制 相关 主要 是 由 转移 指令 引起 的 ,在 遇 到 条 件 转移 指令 时 ,存在 着 是 顺序 执行 还 是 转 
移 执 行 两 种 可 能 ,需要 依据 条 件 的 判断 结果 来 选择 其 一 。 在 无 法 确定 应 该 选择 把 哪 一 程序 
段 安排 在 转移 指令 之 后 来 执行 的 局 面 称 为 控制 相关 ,又 称 指 令 相 关 。 


6.7 精简 指令 系统 计算 机 


精简 指令 系统 计算 机 (RISC) 是 20 世纪 80 年 代 提 出 的 一 种 新 的 设计 思想 ,目前 运行 中 
的 许多 计算 机 都 采用 了 RISC 体系 结构 或 采用 了 RISC 设计 思想 。 


6.7.1 RISC 的 特点 和 优 扫 
1. RISC 的 主要 特点 


目前 ,难以 在 RISC 和 CISC 之 间 划 出 一 条 明显 的 分 界线 ,但 大 部 分 RISC 具有 下 列 一 
些 特点 : 

e。 指令 总 数 较 少 (一 般 不 超过 100 条 ); 

。 基本 寻 址 方式 种 类 少 ( 一 般 限 制 在 2 或 3 种 ); 

。 指令 格式 少 ( 一 般 限制 在 2 或 3 种 ) ,而且 长 度 一 致 ; 

。 除 取 数 和 存 数 指令 (LOAD/STORE) 外 ,大 部 分 指令 在 单 周期 内 完成 ，; 

e。 只 有 取 数 和 存 数 指令 能 够 访问 存储 需 , 其 余 指令 的 操作 只 限于 在 寄存 硕 之 间 进 行 ; 

。 CPU 中 通用 寄存 硕 的 数目 应 相当 多 (32 个 以 上 ,有 的 可 达 上 千 个 ); 
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。 为 提高 指令 执行 速度 , 绝 大 多 数 采 用 便 连 线 控 制 实现 ,不 用 或 少 用 微 程 序 控制 实现 ; 
e 采用 优化 的 编译 技术 ,力求 以 简单 的 方式 文 持 高 级 语言 。 
表 6-3 列 出 了 CISC 和 RISC 的 区 别 。 


表 6-3 CISC 和 RISC 的 区 别 


指令 系统 体系 结构 CISC RISC 


指令 系统 复杂 ,庞大 简单 ,精简 

指令 数目 一 般 大 于 200 条 一 般 小 于 100 条 

指令 字 长 不 固定 等 长 

寻 址 方式 一 般 大 于 4 一 般 小 于 4 

可 访 存 指令 不 加 限制 只 有 LOAD/STORE 指令 
各 种 指令 执行 时 间 相差 较 大 绝 大 多 数 在 一 个 周期 内 完成 
通用 寄存 器 数量 较 少 多 

控制 方式 绝 大 多 数 为 微 程 序 控制 绝 大 多 数 为 硬 布线 控制 

2. RISC 的 优势 

计算 机 执行 一 个 程序 所 用 的 时 间 zt 可 用 下 式 表示 : 


1 一 TIXCXT 
式 中 , 工 是 高 级 语言 编译 后 在 机 器 上 执行 的 机 器 指令 总 数 ,C 是 执行 每 条 机 器 指令 所 需 的 平 
均 周 期 数 ,T 是 每 个 周期 的 执行 时 间 。 表 6-4 为 RISC 和 CISC 的 统计 数据 , 表 中 I、T 为 比 
值 ,C 为 实际 周期 数 。 


表 6-4 RISC\CISC 的 I.C、T 统计 
RISC 1.2~1.4 1l,.3~~1.1 <1 

由 于 RISC 机 器 的 指令 比较 简单 , 故 完成 同样 的 任务 要 比 CISC 机 需 使 用 更 多 的 指令 ， 
因此 RISC 的 工 要 比 CISC 多 20% 一 40%%。 但 是 ,因为 RISC 的 大 多 数 指令 只 需 单 周期 实 
现 , 所 以 C 值 要 比 CISC 小 得 多 。 同 时 因为 RISC 结构 简单 ,所 以 完成 一 个 操作 所 经 过 的 数 
据 通 路 较 短 ,使 醋 值 有 所 减少 ,根据 上 述 统计 折算 下 来 ,RISC 的 处 理 速 度 要 比 相同 规模 的 
CISC 提高 3 一 5 倍 。 

由 于 RISC 的 结构 简化 ,降低 了 芯片 的 复杂 程度 ,节约 了 芯片 面积 。 若 使 RISC 芯片 保 
持 与 CISC 芯片 相同 的 面积 和 复杂 程度 , 则 RISC 芯片 可 集成 更 多 的 功能 部 件 ,集成 度 大 为 
提高 , 且 功 能 也 大 大 加 强 。 

当然 ,RISC 也 存在 着 某 些 局 限 性 ,因此 实际 上 商品 化 的 RISC 机 需 并 不 是 纯粹 的 
RISC。 为 了 满足 应 用 的 需要 ,实用 的 RISC 除了 保持 RISC 的 基本 特色 之 外 ,还 必须 辅 以 一 
些 必 不 可 少 的 复杂 指令 ,如 浮 点 和 十 进 制 运算 指令 等 。 所 以 ,这 种 机 带 实 际 上 是 在 RISC 基 
础 上 实现 了 RISC 与 CISC 的 完美 结合 。 


6.7.2 RISC 基本 技术 
为 了 能 有 效 地 支持 高 级 语言 并 提高 CPU 的 性 能 ,RISC 结构 采用 了 一 些 特殊 技术 。 
1. RISC 寄存 器 管理 技术 


计算 机 中 最 慢 的 操作 是 访问 存储 器 的 操作 ,因此 在 RISC 中 ,为 了 减少 访 存 的 频 度 , 通 
常 在 CPU 沪 片 上 设置 大 量 寄存 器 ,把 常用 的 数据 保存 在 这 些 寄存 器 中 。 例 如 , RISC 了 [有 
138 个 寄存 部 ,AM 29000 有 192 个 寄存 需 ,Ry 公司 的 9000 系列 超级 小 型 机 中 甚至 设置 了 
多 达 528 个 寄存 器 。 

在 RISC 了 [中 使 用 了 重 释 寄存 器 窗口 技术 , 即 设 置 一 个 数量 比较 大 的 寄存 器 堆 , 并 把 它 
划分 成 很 多 窗口 。 每 个 过 程 使 用 其 中 相 邻 的 3 个 窗口 和 一 个 公共 的 窗口 ,而 在 这 相 邻 的 3 
个 窗口 中 有 一 个 窗口 与 前 一 个 过 程 公用 ,还 有 一 个 窗口 是 与 下 一 个 过 程 公 用 的 。 


2. 流水 线 技 术 


一 条 指令 通常 可 分 为 取 指 . 译 码 、 执 行 、. 写 回 等 多 个 阶段 ,要 想 在 一 个 周期 内 串 行 完成 这 
些 操作 是 不 可 能 的 ,因此 ,采用 流水 线 技 术 势 在 必 行 。 

流水 线 的 基本 概念 已 在 前 面 介 绍 过 ,各 种 RISC 采用 的 流水 线 结构 不 完全 相同 。 例 如 ， 
RISCIT 采用 两 级 流水 线 ( 取 指 、 执 行 ),RISC[ 采 用 三 级 流水 线 ( 取 指 、 执 行 、 写 回 ) ,Am 
29000 则 采用 四 级 流水 线 ( 取 指 、 译 码 执行 、 写 回 )。 

当 出 现 数据 相关 和 程序 转移 情况 时 ,流水 线 结构 就 可 能 发 生 断 流 的 问题 ,这 将 会 影响 流 
水 线 的 效率 。 

对 于 两 级 流水 线 不 存在 数据 相关 问题 ,而 流水 线 级 数 越 多 ,情况 越 复 杂 。RISC 是 采 
用 内 部 推 前 的 方法 来 解决 数据 相关 的 问题 的 。 每 当 执 行 LOAD/STORE 指令 时 ,就 把 流水 
线 各 级 操作 暂停 一 个 周期 ,以 完成 存储 需 读 写 , 所 有 指令 的 读 写 运算 结果 总 是 先 放 在 结果 暂 
存 顺 中 。 当 硬件 检测 到 数据 相关 时 ,直接 从 结果 暂 存 器 取得 源 操作 数 , 即 将 与 第 z 十 1 条 指 
令 操 作 有 关 的 第 i 条 指令 的 数据 预先 推 人 一 个 暂 存 器 中 ,所 以 第 i 十 1 条 指令 是 从 暂 存 器 中 
取出 操作 数 的 ,这 样 使 流水 线 不 至 于 阻塞 。 


3. 延 时 转移 技术 


在 流水 线 中 , 取 下 一 条 指令 是 同上 一 条 指令 的 执行 并 行进 行 的 , 当 遇 到 转移 指令 时 , 流 
水 线 就 可 能 断 流 。RISC 机 带 中 , 当 遇 到 转移 指令 时 ,可 以 采用 延迟 转移 方法 或 优化 延迟 转 
移 方 法 。 在 采取 延迟 转移 方法 时 ,编译 程序 自动 在 转移 指令 之 后 插入 一 条 (或 几 条 ,根据 流 
水 线 情 况 而 定 ) 空 指令 ,以 延迟 后 继 指令 进入 流水 线 的 时 间 。 所 谓 优化 延迟 转移 方法 ,是 将 
转移 指令 与 前 条 指令 对 换 位 置 ,提前 执行 转移 指令 ,可 以 节省 一 个 机 需 周 期 。 


6.8 微 处 理 怖 中 的 新 技术 


6.8.1 超标 量 和 超 流水 线 技术 
在 RISC 之 后 ,出 现 了 一 些 提高 指令 级 并 行 性 的 技术 ,使 得 计算 机 在 每 个 时 钟 周 期 里 可 
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以 解释 多 条 指令 ,这 就 是 超标 量 技术 和 超 流 水 线 技术 。 

前 面 提 到 的 流水 线 技术 是 指 常规 的 标量 流水 线 , 每 个 时 钟 周 期 平均 执行 的 指令 的 条 数 
小 于 或 等 于 1, 即 它 的 指令 级 并 行 度 (Instruction Level Parallelism,ILP) 三 1。 

超标 量 技术 是 通过 重复 设置 多 个 功能 部 件 , 并 让 这 些 功 能 部 件 同时 工作 来 提高 指令 的 执 
行 速度 ,实际 上 是 以 增加 硬件 资源 为 代价 来 换取 处 理 需 性 能 的 。 使 用 超标 量 技术 的 处 理 需 在 
一 个 时 钟 周期 内 可 以 同时 发 射 多 条 指令 ,假设 每 个 时 钟 周 期 发 射 m 条 指令 , 则 有 1 过 ILP 一 mm。 

超 流水 线 仍然 是 一 种 流水 线 技术 ,可 以 认为 它 是 将 标量 流水 线 的 子 过 程 ( 段 ) 再 进一步 
细 分 ,使 得 子 过 程 数 ( 段 数 ) 大 于 或 等 于 8 的 情况 。 也 就 是 说 ,只 需要 增加 少量 硬件 ,通过 各 
部 分 便 件 的 充分 重 全 工作 来 提高 处 理 右 性能。 采用 超 流水 线 技 术 的 处 理 右 在 一 个 时 钟 周期 
内 可 以 分 时 发 射 多 条 指令 ,假设 每 个 时 钟 周 期 At 分 时 地 发 射 n 条 指令 , 则 每 隔 Az 就 流出 一 
条 指令 ,此 时 Az =At/m ,有 1 一 ILP 一 "。 


6.8.2 EPIC 的 指令 级 并 行 处 理 


EPIC 架构 是 Itanium 挑战 RISC 架构 的 基础 , 它 的 设计 思想 就 是 用 智能 化 的 软件 来 指 
挥 硬 件 , 以 实现 指令 级 并 行 计算 。 采 用 EPIC 架构 的 处 理 器 在 运行 中 ,首先 由 编译 器 分 析 指 
令 之 间 的 依赖 关系 ,将 没有 依赖 关系 的 3 条 指令 组 合成 一 个 128 位 的 指令 束 。 在 低 端 CPU 
中 ,每 个 时 钟 周期 调度 1 个 指令 束 ,CPU 等 待 折 有 的 指令 都 执行 完 后 再 调度 下 一 个 指令 束 。 
在 高 端的 CPU 中 ,每 个 时 钟 周 期 可 以 调用 多 个 指令 束 , 类 似 于 现在 的 超标 量 设计 。 男 外 ， 
在 高 端 CPU 中 ,CPU 可 以 在 原 有 的 指令 束 没 有 执行 完 之 前 调度 新 的 指令 束 。 当 然 , 它 需要 
检查 将 要 用 到 的 寄存 器 和 功能 单元 是 否 可 用 ,但 是 它 不 用 检查 同一 束 中 的 其 他 指令 是 否 和 
它 冲 突 , 因 为 编译 器 已 经 保证 不 会 出 现 这 种 情况 。 

值得 一 提 的 是 ,EPIC 还 采用 了 更 为 先进 的 分 文 判 定 技术 来 保证 并 行 处 理 的 稳定 性 。 
传统 CPU 采用 的 分 支 预测 技术 是 只 沿 一 个 预测 的 分 支 执行 , 一 旦 预测 错误 就 不 得 不 清空 
整 条 流水 线 , 从 头 再 来 ,损失 较 大 ;EPIC 的 分 文 判定 技术 则 是 同时 执行 两 条 分 支 , 把 条 件 分 
文 指令 变 成 可 同时 执行 的 判定 指令 ,让 两 条 分 文 并 行 执行 ,最 后 丢掉 不 需要 的 结果 即 可 。 

另外 ,EPIC 还 导入 了 数据 推测 装载 技术 , 它 可 预选 在 Cache 中 装 入 接 下 来 的 指令 可 能 
调用 的 数据 ,来 提升 Cache 的 工作 效率 ,对 经 稼 需要 使 用 Cache 的 应 用 程序 (如 大 型 数据 库 ) 
的 性 能 提升 非常 显著 。 


6.8.3 超 线 程 技 术 


超 线程 (Hyper-Threading, HT) 是 Intel 公司 提出 的 一 种 提高 CPU 性 能 的 技术 ,简单 
地 说 就 是 将 一 个 物理 CPU 当 作 两 个 逻辑 CPU 使 用 ,使 CPU 可 以 同时 执行 多 重 线程 ,从 而 
发 挥 更 大 的 效率 。 超 线程 技术 利用 特殊 的 硬件 指令 ,把 两 个 逻辑 内 核 模拟 成 两 个 物理 心 片 ， 
让 单个 处 理 器 都 能 使 用 线程 级 并 行 计 算 , 进 而 兼容 多 线程 操作 系统 和 应 用 软件 ,减少 了 
CPU 的 闲置 时 间 ,提高 了 CPU 的 运行 效率 。 

超 线程 技术 可 以 使 操作 系统 或 者 应 用 软件 的 多 个 线程 同时 运行 于 一 个 超 线 程 处 理 需 
上 ,其 内 部 的 两 个 逻辑 处 理 需 共享 一 组 处 理 器 执行 单元 ,并行 完成 加 、. 乘 .加载 等 操作 。 这 样 
做 可 以 使 得 处 理 器 的 处 理 能 力 提 高 30% ,因为 在 同一 时 间 里 应 用 程序 可 以 充分 使 用 芯片 的 
各 个 运算 单元 。 


记 风 处 理 器 


对 于 单线 程 芯 片 来 说 ,虽然 也 可 以 每 秒 钟 处 理 成 千 上 万 条 指令 ,但 是 在 某 一 时 刻 它 只 能 
够 对 一 条 指令 (单个 线程 ) 进 行 处 理 , 结 果 必 然 使 处 理 器 内 部 的 其 他 处 理 单元 闲置 。 而 超 线 
程 技 术 则 可 以 使 处 理 器 在 某 一 时 刻 同步 并 行 处 理 更 多 指令 和 数据 (多 个 线程 )。 所 以 , 超 线 
程 是 一 种 可 以 将 CPU 内 部 暂时 闲置 处 理 资源 充分 “调动 ”起 来 的 技术 。 

在 处 理 多 个 线程 的 过 程 中 ,多 线程 处 理 需 内 部 的 每 个 逻辑 处 理 需 均 可 以 单独 对 中 断 做 
出 啊 应 , 当 第 一 个 逻辑 处 理 需 跟 踩 一 个 软件 线程 时 ,第 二 个 逻辑 处 理 需 也 开始 对 另外 一 个 软 
件 线程 进行 跟踪 和 处 理 了 。 另 外 ,为 了 避免 CPU 处 理 资源 冲突 ,负责 处 理 第 二 个 线程 的 那 
个 逻辑 处 理 需 ,其 使 用 的 仅 是 运行 第 一 个 线程 时 被 暂时 闲置 的 处 理 单 元 。 例 如 , 当 一 个 逻辑 
处 理 需 在 执行 浮 点 运算 (使 用 处 理 需 的 浮 点 运算 单元 ) 时 , 另 一 个 逻辑 处 理 需 则 可 以 执行 加 
法 运算 (使 用 处 理 需 的 整数 运算 单元 ) 。 这 样 做 ,无 疑 大 大 提高 了 处 理 硕 内 部 处 理 单元 的 利 
用 率 和 相应 数据 .指令 的 吞吐 能 力 。 

超 线程 技术 实现 的 前 提 条 件 是 需要 五 大 文 持 , 即 CPU 支持 、 主 板 必 片 组 文 持 、 主 板 
BIOS 支持 ,操作 系统 支持 和 应 用 软件 支持 。 只 有 满足 这 些 条 件 , 才 能 使 得 系统 效能 得 到 提 
升 。 需 要 指出 的 是 , 超 线程 技术 仅 在 多 任务 处 理 时 有 优势 ,在 进行 单个 任务 处 理 时 ,优势 表 
现 不 出 来 ,而 且 因 为 打开 了 超 线程 (在 BIOS 中 ) ,处 理 需 内 部 缓存 就 会 被 划分 成 几 个 区 域 ， 
互相 共享 内 部 资源 ,反而 会 造成 单个 的 子 系统 性 能 下 降 。 

超 线程 技术 最 早出 现在 2002 年 推出 的 Pentium 4 上 ,但 由 于 当时 支持 超 线程 技术 的 应 
用 软件 缺少 ,使 得 它 的 优势 无 法 发 挥 ,之 后 Intel 公司 推出 的 一 些 处 理 器 也 曾 不 再 使 用 这 个 
技术 。 直 至 2009 年 Core i 系列 的 诞生 , 超 线 程 技术 才 有 卷土重来 之 势 , 如 四 核 的 Core i7 可 
同时 文 持 8 个 线程 工作 ,大 幅 增 强 其 多 线程 性 能 。 


6.8.4 双核 与 多 核 技 术 
1. 双核 处 理 器 


双核 处 理 器 是 指 在 一 个 处 理 器 上 集成 两 个 运算 核心 ,从 而 提高 计算 能 力 。“ 双 核 ” 的 概 
念 最 早 是 由 IBM、HP、Sun 等 支持 RISC 架构 的 高 端 服务 右 厂 商 提出 的 ,目前 双核 处 理 器 已 
在 微机 中 普遍 使 用 ,图 6-27 给 出 了 Intel 双核 的 基本 结构 。 

双核 处 理 器 并 不 能 达到 1 十 1=2 的 效果 ,也 就 是 说 ,双核 
处 理 需 并 不 会 比 同 频率 的 单 核 处 理 吉 提高 一 倍 的 性 能 。IBM 
公司 曾经 对 比 了 AMD 双核 处 理 器 和 单 核 处 理 器 的 性 能 ,其 结 
果 是 双核 和 单 核 相 比 大 概 性 能 提高 60%。 不 过 值得 一 提 的 
是 ,这 个 60% 并 不 是 说 处 理 同一 个 程序 时 的 提升 幅度 ,而 是 在 
多 线程 任务 下 得 到 的 提升 。 换 句 话 说 ,双核 处 理 器 的 优势 在 
于 多 线程 应 用 ,如 果 只 是 处 理 单个 任务 ,运行 单个 程序 ,也 许 双 
核 处 理 需 与 同 频率 的 单 核 得 到 的 效果 是 一 样 的 。 6-27 ”Intel 双核 的 基本 结构 


2. 超 线 程 技术 与 双核 心 技 术 的 区 别 


开启 了 超 线 程 技 术 的 Pentium 4( 单 核 ) 与 Pentium D( 双 核 ) 在 操作 系统 中 都 同样 被 识 
别 为 两 个 处 理 带 ,它们 究竟 是 不 是 一 样 的 呢 ?” 这 个 问题 确实 具有 迷惑 性 。 其 实 , 可 以 人 简单 地 


Execution © Execution 


二 


把 双核 心 技 术 理解 为 两 个 "物理 "处理 豆 , 是 一 种 " 便 ” 的 方式 ;而 超 线程 技术 只 是 两 个 “逻辑 ” 
处 理 豆 ,是 一 种 " 软 "的 方式 。 

文 持 超 线程 的 Pentium 4 能 同时 执行 两 个 线程 ,但 超 线 程 中 的 两 个 逻辑 处 理 右 并 没有 
独立 的 执行 单元 \ 整 数 单元 .寄存 需 甚 至 缓存 等 贫 源 。 它 们 在 运行 过 程 中 仍 需要 共用 执行 单 
元 、 缓 在 和 系统 总 线 接口 。 在 执行 多 线程 时 两 个 逻辑 处 理 天 均 是 交 蔡 工作 ,如 果 两 个 线程 都 
同时 需要 某 一 个 殴 源 时 ,其 中 一 个 要 暂停 并 要 让 出 资源 ,要 竺 那些 资源 闲置 时 才能 继续 。 因 
此 , 超 线程 技术 仅 可 以 视 为 对 单个 处 理 融 运算 资源 的 优化 利用 。 

而 双核 心 技术 则 是 通过 “ 便 ” 的 物理 核心 实现 多 线程 工作 的 : 每 个 核心 拥有 独立 的 指令 
集 、 执 行 单元 ,与 超 线 程 中 所 采用 的 模拟 共享 机 制 完全 不 一 样 。 在 操作 系统 看 来 , 它 是 实 实 
在 在 的 双 处 理 带 ,可 以 同时 执行 多 项 任务 ,能 让 处 理 副 资源 真正 实现 并 行 处 理 模式 ,其 效率 
和 性 能 提升 要 比 超 线程 技术 高 得 多 ,不 可 同日 而 请 。 


3. 多 核 多 线程 技术 


目前 ,高 性 能 微 处 理 希 研究 的 前 沿 逐 渐 从 开发 指令 级 并 行 (ILP) 转 加 开发 多 线程 并 行 
(Thread Level Parallelism,TLP), 单 心 片 多 处 理 器 (Chip Multiprocessor,CMP) 就 是 实现 
TLP 的 一 种 新 型 体系 结构 。 

CMP 在 一 个 芯片 上 集成 多 个 微 处 理 硕 核 ,每 个 微 处 理 需 核实 质 上 都 是 一 个 相对 简单 的 
单线 程 微 处 理 需 或 者 比较 简单 的 多 线程 微 处 理 需 ,这 样 多 个 微 处 理 器 核 就 可 以 并 行 地 执行 
程序 代码 ,因而 具有 较 高 的 线程 级 并 行 性 。 

如 果 按 照 单 忌 片 多 处 理 硕 上 的 处 理 希 是 否 相 同 划 分 ,可 以 分 为 同 构 CMP 和 异 构 CMP， 
同 构 CMP 大 多 数 由 通用 的 处 理 需 组 成 ,多 个 处 理 需 执行 相同 或 者 类 似 的 任务 。 异 构 CMP 
除 含 有 通用 处 理 天 作为 控制 .通用 计算 之 外 ,多 集成 了 DSP、ASIC、 媒 体 处 理 融 、VLIW 处 理 
天 等 针对 特定 的 应 用 提高 计算 的 性 能 。 

Pentium 系列 微 处 理 大 中 的 Pentium 属于 单 核 单线 程 处 理 需 ,Pentium 4 属于 单 核 多 线 
程 处 理 器 ,Pentium D 属于 多 核 单 线程 处 理 器 ,Pentium EE 属于 多 核 多 线程 处 理 器 ,这 几 种 
微 处 理 需 的 内 部 结构 示意 图 如 图 6-28 所 示 , 图 中 EU 表示 执行 单元 ,CU 表示 控制 单元 。 


本 而 本 而 而 
(a) 单 核 单线 程 处 理 右 (b) 单 核 多 线程 处 理 费 


Cache 
(c) 多 核 单 线程 处 理 费 (d) 多 核 多 线程 处 理 器 
图 6-28 几 种 微 处 理 器 的 内 部 结构 


目前 ,市 面 上 已 大 量 出 现 三 核 、 四 核 , 六 核 和 八 核 的 处 理 器 ,其 至 有 十 核 和 十 二 核 的 面向 
服务 器 和 工作 站 的 处 理 器 ,如 Intel 的 Xeon E5 就 有 八 核 十 六 进程 。 
多 核 处 理 需 广泛 受到 青睐 的 一 个 主要 原因 是 , 当 工 作 频 率 受 限于 技术 进步 时 ,并 行 处 理 


因 央 处 理 器 


技术 可 以 采用 更 多 的 内 核 并 行 运行 来 大 大 提高 处 理 表 的 等 效 运行 速度 ,同时 由 于 工作 频率 
没有 提高 , 功 耗 相对 于 同性 能 的 高 频 单 核 处 理 表 要 低 得 多 。 不 难看 出 ,多 核 处 理 天 是 处 理 表 
发 展 的 必然 趋势 。 无 论 是 移动 与 艇 人 式 应 用 、 困 面 应 用 还 是 服务 天 应 用 ,都 将 采用 多 核 的 絮 
构 。 未 来 的 多 核 处 理 需 必 片 将 包含 很 多 通用 的 处 理 需 核 , 每 个 处 理 融 核 运行 2 一 4 个 线程 。 
同时 必 片 中 包含 成 千 个 异 构 可 编程 加 速 关 ,用 于 媒体 加 速 等 特殊 处 理 。 


6.8.5 蹇 频 加 速 技术 


窗 频 加 速 技术 的 英文 全 称 是 Intel Turbo Boost Technology, 它 是 Intel Core i57i7 处 理 
器 的 独 有 特性 ,也 是 Intel 公司 新 宣布 的 一 项 技术 。 寄 频 加 速 技术 可 以 理解 为 自动 超频 , 实 
际 上 是 一 个 新 一 代 的 能 效 管理 方案 。 

当 启 动 一 个 运行 程序 后 ,处 理 器 会 自动 加 速 到 合适 的 频率 ,而 原来 的 运行 速度 会 提升 
10% 一 20% ,以 保证 程序 流畅 运行 。 应 对 复杂 应 用 时 ,处 理 器 可 自动 提高 运行 主 频 以 提高 速 
度 ,轻松 进行 对 性 能 要 求 更 高 的 多 任务 处 理 ; 当 进行 工作 任务 切换 时 ,如 果 只 有 内 存 和 硬盘 
在 进行 主要 的 工作 ,处 理 器 会 立刻 处 于 节 电 状态 ,这 样 既 保 证 了 能 源 的 有 效 利用 ,又 使 程序 
速度 大 幅 提 升 。 通 过 智能 化 地 加 快 处 理 需 速度 ,从 而 根据 应 用 需求 最 大 限度 地 提升 性 能 ,为 
高 负载 任务 提升 运行 主 频 高 达 20%。 

Turbo Boost, 顾 名 思 义 就 是 加 速 技术 , 它 是 新 一 代 CPU 的 趋势 ,使 得 CPU 更 加 智能 。 
CPU 会 确定 其 当前 工作 功率 .电流 和 温度 是 否 已 达到 最 高 极限 ,如 仍 有 多 余 空 间 ,CPU 会 
逐渐 提高 活动 内 核 的 频率 ,以 进一步 提高 当前 任务 的 处 理 速度 , 当 程 序 只 用 到 其 中 的 某 些 核 
心 时 ,CPU 会 自动 关闭 其 他 未 使 用 的 核心 。 当 开启 窖 频 加 速 之 后 ,CPU 会 根据 当前 的 任务 
量 自动 调整 CPU 主 频 ,从 而 是 重任 务 时 发 挥 最 大 的 性 能 ,是 轻 任 务 时 发 挥 最 大 节能 优势 。 
寄 频 加 速 技 术 无 须 用 户 干 预 ,自动 实现 ,而 且 完 全 让 CPU 运行 在 技术 规范 内 ,安全 可 靠 ,不 
需要 任何 额外 的 投资 ,系统 运行 稳定 ,在 不 影响 CPU 的 热 功 耗 设计 (TDP) 情 况 下 ,能 把 核 
心 工 作 频 率 调 得 更 高 。 

Turbo Boost 是 基于 CPU 的 电源 管理 技术 来 实现 的 ,通过 分 析 当 前 CPU 的 负载 情 
况 ,智能 地 完全 关闭 一 些 用 不 上 的 核心 ,把 能 源 留 给 正在 使 用 的 核心 ,并 使 它们 运行 在 更 
高 的 频率 ,从 而 提供 更 强 的 性 能 。 而 需要 多 个 核心 时 , 则 动态 开启 相应 的 核心 ,智能 调整 

在 进入 Turbo 方式 后 ,繁忙 CPU 内 核 的 频率 会 提升 一 级 , 通常 每 个 时 钟 提升 步 进 是 
133MHz。 以 实际 发 布 的 一 球 Core 17-870 为 例 ,这 是 一 款 四 核 八 线程 的 处 理 右 ,其 CPU 主 
频 为 2.93GHz。 如 果 只 有 一 个 内 核 处 于 运行 状态 ,这 个 内 核 可 以 提速 至 3. 6GHz( 最 大 窗 
频 ) ,相当 于 上 5 个 台阶 ,增加 了 5X133MHz。 如 果 只 有 2 个 内 核 处 于 运行 状态 ,这 2 个 内 
核 可 以 提速 至 3.46GHz, 相 当 于 上 了 4 个 台阶 ,增加 了 4X133MHz。 如 果 3 个 或 者 4 个 内 
核 处 于 运行 状态 ,这 个 处 理 器 可 以 提速 到 3.2GHz, 相 当 于 上 了 2 个 台阶 ,增加 了 2X133MHz。 

寄 频 加 速 2. 0 技术 的 英文 全 称 是 Turbo Boost 2.0, 相 比 窒 频 1. 0 来 说 , 寄 频 2.0 的 特 
点 有 两 点 : 一 是 更 加 智能 、 更 高 能 效 , 宕 频 2. 0 不 再 受 TDP 限制 ,而 是 通过 CPU 内 部 温度 
进行 监测 ,在 CPU 内 部 温度 许可 的 情况 下 可 以 超过 TDP 提供 更 大 的 寄 频 幅度 ,不 寄 频 时 却 
更 节能 ;二 是 CPU 和 GPU 都 可 以 窒 频 ,而 且 可 以 一 起 窒 频 。 简 单 地 说 , 割 频 加 速 技 术 2.0 
更 智能 、 更 高 效 。 


三 坟 吕 
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2016 年 ,Intel 公司 推出 了 面 癌 发 烧 级 平台 的 容 频 加 速 Max 技术 3. 0 (Turbo Boost 
Max Technology 3.0)。 它 可 以 将 处 理 右 的 单线 程 多 核 性 能 提升 15% 以 上 。 在 寄 频 3.0 
技术 中 ,将 1 或 2 颗 体 质 最 好 的 处 理 右 核心 定义 为 最 佳 性 能 核心 ,然后 尽 可 能 提升 它们 的 频 
率 ,从 而 满足 更 复杂 场景 的 应 用 需求 。 容 频 加 速 Max 技术 3.0 不 会 取代 蹇 频 加 速 技术 
2.0。 前 者 对 后 者 进行 了 增强 ,可 大 幅 提 高 最 快 内 核 的 频率 ,从 而 让 用 户 能 够 更 加 灵活 地 获 
得 章 越 的 处 理 右 性 能 。 


习 题 


6-1 控制 器 有 哪 几 种 控制 方式 ? 各 有 何 特点 ? 

6-2 什么 是 三 级 时 序 系统 ? 

6-3 ”控制 器 有 哪些 基本 功能 ? 它 可 分 为 哪 几 类 ? 分 类 的 依据 是 什么 ? 

6-4 中 央 处 理 器 有 哪些 功能 ? 它 由 哪些 基本 部 件 组 成 ? 

6-5 ”中央 处 理 器 中 有 哪 几 个 主要 寄存 器 ? 试 说 明 它 们 的 结构 和 功能 。 

6-6 某 计 算 机 CPU 芯片 的 主 振 频 率 为 8MHz, 其 时 钟 周 期 是 多 少 微 秒 ? 若 已 知 每 个 机 器 周期 平均 包 
含 4 个 时 钟 周 期 ,该 机 的 平均 指令 执行 速度 为 0.8MIPS ,试问 : 

(1) 平均 指令 周期 是 多 少 微 秒 ? 

(2) 平均 每 个 指令 周期 含有 多 少 个 机 器 周期 ? 

(3) 若 改 用 时 钟 周期 为 0. 4ps 的 CPU 芯片 , 则 计算 机 的 平均 指令 执行 速度 又 是 多 少 MIPS? 

(4) 若 要 得 到 40 万 次 / 秒 的 指令 执行 速度 , 则 应 采用 主 频 为 多 少 MHz 的 CPU 芯片 ? 

6-7 以 一 条 典型 的 单 地 址 指令 为 例 , 简 要 说 明 下 列 部 件 在 计算 机 的 取 指 周期 和 执行 周期 中 的 作用 。 

(1) 程序 计数 器 (PC) 。 

(2) 指令 寄存 器 (IR)。 

(3) 算术 逻辑 运算 部 件 (ALU) 。 

(4) 存储 器 数据 寄存 器 (MDR ) 。 

(5) 存储 器 地 址 寄存 器 (MAR) 。 

6-8 什么 是 指令 周期 ? 什么 是 CPU 周期 ? 它们 之 间 有 什么 关系 ? 

6-9 指令 和 数据 都 存放 在 主 存 ,如何 识 别 从 主 存储 器 中 取出 的 是 指令 还 是 数据 ? 

6-10 ”CPU 中 指令 寄存 器 是 否 可 以 不 要 ? 指令 译 码 器 是 否 能 直接 对 存储 器 数据 寄存 器 MDR 中 的 信息 译 
码 ? 为 什么 ? 以 无 条 件 转移 指令 JMP A 为 例 说 明 。 

6-11 设 一 地 址 指令 格式 如 下 : 


现在 有 4 条 一 地 址 指令 : LOAD( 取 数 )、ISZ( 加 “1” 为 零 跳 )、DSZ( 减 “1” 为 
零 跳 )、.STORE( 存 数 ) ,在 一 台 单 总 线 单 累加 器 结构 的 机 器 上 运行 , 试 排出 这 4 
个 指令 的 微 操作 序列 。 

注意 : 当 排 ISZ 和 DSZ 指令 时 不 要 破坏 累加 寄存 器 Acc 原来 的 内 容 。 

6-12 某 计 算 机 的 CPU 内 部 结构 如 图 6-29 所 示 。 两 组 总 线 之 间 的 所 有 
数据 传送 通过 ALU。ALU 还 具有 完成 以 下 功能 的 能 力 : 

F 一 人 A; F=B 

F=A+1l; F=B+l 6-29 茶 计算 机 CPU 

F=A—1; F=B-—1 内 部 结构 


记 风 处 理 器 


写 出 转子 指令 (JSR) 的 取 指 和 执行 周期 的 微 操 作 序 列 。JSR 指令 占 两 个 字 ,第 一 个 字 是 操作 码 , 第 二 
个 字 是 子 程序 的 入 口 地 址 。 返 回 地址 保存 在 存储 器 堆栈 中 ,堆栈 指示 器 始终 指向 栈 顶 。 
6-13” 某 计算 机 主要 部 件 如 图 6-30 所 示 。 
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图 6-30 某 计 算 机 主要 部 件 
LA 一 一 A 输入 选择 器 ”LB 一 一 B 输 入 选择 器 ”C.D 一 一 暂 存 器 


(1) 补充 各 部 件 间 的 主要 连接 线 , 并 注 明 数据 流动 方 癌 。 

(2) 写 出 指令 ADD (CR: ),(R: ) 十 的 执行 过 程 ( 含 取 指 过 程 与 确定 后 继 指令 地 址 ) 。 该 指令 的 含义 是 进 
行 加 法 操作 , 源 操作 数 地 址 和 目的 操作 数 地 址 分 别 在 寄存 器 Ri 和 R: 中 ,目的 操作 数 寻 址 方式 为 自 增 型 寄 
存 右 间 址 。 

6-14 CPU 结构 如 图 6-31 所 示 ,其 中 有 一 个 累加 寄存 器 AC. 一 个 程序 状态 字 寄 存 器 和 其 他 4 个 寄存 
句 , 各 部 件 之 间 的 连 线 表示 数据 通路 ,箭头 表示 信息 传送 方 问 。 

(1) 标明 4 个 寄存 需 的 名 称 。 

(2) 简 述 指令 从 主 存 取出 送 到 控制 器 的 数据 通路 。 

(3) 简 述 数据 在 运算 器 和 主 存 之 间 进 行 存 取 访问 的 数据 通路 。 


主 存储 咒 M 
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图 6-31 某 计 算 机 CPU 结构 


6-15 ”什么 是 微 命令 和 微 操作 ? 什么 是 微 指令 ? 微 程序 和 机 器 指令 有 何 关 系 ? 微 程 序 和 程序 之 间 有 
何 关 系 ? 

6-16 ”什么 是 垂直 型 微 指令 ? 什么 是 水 平 型 微 指令 ? 它们 各 有 什么 特点 ? 又 有 什么 区 别 ? 

6-17 ”水平 型 和 垂直 型 微 程 序 设 计 之 间 有 什么 区 别 ? 串 行 微 程 序 设计 和 并 行 微 程 序 设 计 有 什么 区 别 ? 

6-18 图 6-32 给 出 了 某 微 程 序 控制 计算 机 的 部 分 微 指令 序列 。 图 中 每 一 框 代 表 一 条 微 指令 。 分 支点 
a 由 指令 寄存 器 (IR) 的 第 5 和 6 两 位 决定 。 分 支点 b 由 条 件 码 Co 决定 。 已 知 微 指令 地 址 寄存 器 字 长 8 位 ， 
现 采用 下 址 字段 实现 该 序列 的 顺序 控制 。 

(1) 设计 实现 该 微 指令 序列 的 微 指令 字 之 顺序 控制 字段 格式 。 

(2) 给 出 每 条 微 指 令 的 二 进 制 编码 地 址 。 

(3) 画 出 微 程序 控制 器 的 简化 框图 。 

6-19 已 知 某 计算 机 采用 微 程序 控制 方式 ,其 控制 存储 器 容量 为 512X 48 位 , 微 程序 可 在 整个 控制 存 
储 器 中 实现 转移 ,可 控制 转移 的 条 件 共 4 个 , 微 指令 采用 水 平 型 格 式 , 后 继 指 令 地 址 采用 断定 方式 , 微 指令 
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图 6-32 某 计 算 机 的 部 分 微 指 令 序 列 
格式 如 图 6-33 所 示 。 


判别 测试 字段 | 下 地 址 字段 


顺序 控制 
图 6-33 某 计 算 机 的 微 指 令 格式 


(1) 微 指令 中 的 3 个 字段 分 别 应 为 多 少 位 ? 
(2) 画 出 围绕 这 种 微 指令 格式 的 微 程序 控制 器 逻辑 框图 。 
6-20” 某 计算 机 有 8 条 微 指 令 工 一 ,每 条 微 指令 所 含 的 微 命令 控制 信号 如 表 6-5 所 示 。 


表 6-5 微 指令 所 含 微 命令 控制 信号 


微 指令 
:|b | :| | ss +b | i | 


而 尖 加 | 
, 一 


a 一 j 分 别 代表 10 种 不 同性 质 的 微 命令 信号 ,假设 一 条 微 指令 的 操作 控制 字段 为 8 位 ,安排 微 指 令 的 
操作 控制 字段 格式 ,并 将 全 部 微 指 令 代 码 化 。 

6-21 在 微 程序 控制 器 中 , 微 程序 计数 器 (xPC) 可 以 用 具有 加 “1” 功 能 的 微 地 址 寄存 器 (xMAR) 来 代 
蔡 ,试问 程序 计数 器 (PC) 是 否 可 以 用 具有 加 “1” 功 能 的 存储 器 地 址 寄存 器 (MAR) 代 车? 
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在 大 多 数 计算 机 系统 中 ,无论 是 计算 机 内 部 各 部 分 之 间 ,还 是 计算 机 与 外 部 设备 之 间 ， 
数据 传送 都 是 通过 总 线 (Bus) 进 行 的 。 可 以 说 ,总 线 是 计算 机 及 其 系统 的 重要 组 成 部 分 。 
本 章 介 绍 总 线 的 有 关 概 念 、 总 线 仲 裁 方法 、 总 线 操作 定时 与 常见 总 线 标准 。 


7.1 总 线 概 述 


总 线 是 一 组 能 为 多 个 部 件 分 时 共享 的 公共 信息 传送 线路 。 共 享 是 指 总 线 上 可 以 挂 接 多 
个 部 件 , 各 个 部 件 之 间 相 互 交 换 的 信息 都 可 以 通过 这 组 公共 线路 传送 ;分 时 是 指 同一 时 刻 总 
线 上 只 能 传送 一 个 部 件 发 送 的 信息 。 


7.1.1 总 线 的 基本 概念 


总 线 采 用 分 时 共 圣 技术 , 当 总 线 空 用 (所 有 部 件 都 以 高 阻 状态 连接 在 总 线 上 ) 时 ,如 果 有 
一 个 部 件 要 与 目的 部 件 通 信 , 则 发 起 通信 的 部 件 驱 动 总 线 , 发 出 地 址 和 数据 。 其 他 以 高 阻 状 
态 连 接 在 总 线 上 的 部 件 , 如 果 收 到 与 日 己 相 符 的 地 址 信息 后 , 即 接收 总 线 上 的 数据 。 发 送 部 
件 完 成 通信 后 ,将 总 线 让 出 (输出 变 为 高 阻 态 ) 。 


1. 三 态 门 和 总 线 电路 


高 阻 状态 又 称 浮 空 状态 ,输出 呈 高 阻 状态 即 相 当 于 输出 开路 ( 隅 断 ) ,输出 妆 对 地 的 电阻 
无 限 大 ,与 外 界 断 开 联系 。 有 具备 高 阻 状态 的 门 电路 称 为 三 态 门 , 即 具 有 3 种 逻辑 状态 (逻辑 
0 逻辑 1 和 高 阻 状态 ) 的 门 电路 。 三 态 门 除了 正常 的 输入 端 和 输出 端 之 外 ,还 有 一 个 控制 端 
G( 或 G) 。 只 有 当 控 制 端 有 效 时 ,该 三 态 门 才 能 满足 正常 的 逻辑 关系 ;否则 ,输出 将 呈现 高 阻 
状态 。 根 据 输入 输出 关系 和 控制 端的 有 效 电 平 ,可 以 分 为 4 种 类 型 的 三 态 门 ,如 


图 7-1 所 示 。 
V Vp 一 V 一 Vp 
(a) (b) (c) (d) 


7-1 4 种 类 型 的 三 态 门 


心 | 
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三 态 门 主要 用 于 总 线 连接 ,各 个 部 件 或 设备 必须 通过 三 态 缓 冲 器 才能 挂 在 总 线 上 ,通过 
控制 端 选择 工作 部 件 或 设备 。 

按 总 线 的 逻辑 结构 来 看 ,有 单身 总 线 和 双 回 总 线 之 分 , 单 问 总线 是 指 总 线 上 的 信息 只 能 
向 一 个 方向 传送 ,双向 总 线 是 指 总 线 上 的 信息 可 以 向 两 个 方向 传送 。 例 如 ,数据 总 线 是 双向 
三 态 的 , 既 可 以 把 CPU 的 数据 传送 到 存储 器 或 W/O 设备 ,也 可 以 将 其 他 部 件 的 数据 传送 到 
CPU; 而 地 址 总 线 是 单 向 三 态 的 ,地 址 只 能 从 CPU 传 加 存储 需 或 IO 设备。 


2. 总 线 事务 


通常 把 在 总 线 上 一 对 设备 之 间 的 一 次 信息 交换 过 程 称 为 一 个 “总 线 事务 ”, 把 发 出 总 线 
事务 请 求 的 部 件 称 为 主 设 备 ,与 主 设备 进行 信息 交换 的 对 象 称 为 从 设备 。 例 如 ,CPU 要 求 
谈 取 存储 天 中 某 单元 的 数据 , 则 CPU 是 主 设备 ,而 存储 胡 是 从 设备 。 总 线 事务 类 型 通常 根 
据 它 的 操作 性 质 来 定义 ,典型 的 总 线 事 务 类 型 有 "存储 天 谈 玉 存储 天 写 “I/O 读 “I/O 写 ” 
和 “中断 啊 应 ”等 ,一 次 总 线 事务 简单 来 说 包括 两 个 阶段 :地址 阶段 和 数据 阶段 。 

突 发 传送 事务 由 一 个 地 址 阶段 和 多 个 数据 阶段 构成 ,用 于 传送 多 个 连续 单元 的 数据 ,地 
址 阶段 送出 的 是 连续 区 域 的 首 地 址 。 因 此 ,一 次 突 发 传送 事务 可 以 传送 多 个 数据 。 


3. 总 线 使 用 权 


总 线 是 由 多 个 部 件 和 设备 所 共享 的 ,为 了 正确 地 实现 它们 之 间 的 通信 ,必须 有 一 个 总 线 
控制 机 构 ,对 总 线 的 使 用 进行 合理 的 分 配 和 管理 。 

主 设备 发 出 总 线 请 求 并 获得 总 线 使 用 权 后 ,就 立即 开始 向 从 设备 进行 一 次 信息 传送 。 
这 种 以 主 设备 为 参考 点 , 回 从 设备 发 送信 息 或 接收 从 设备 送 来 的 信息 的 工作 关系 , 称 为 主 从 
关系 。 主 设备 负责 控制 和 支配 总 线 , 癌 从 设备 发 出 命令 来 指定 数据 传送 方式 与 数据 传送 地 
址 信息 。 各 设备 之 间 的 主 从 关系 不 是 固定 不 变 的 ,只 有 获得 总 线 使 用 权 的 设备 才 是 主 设备 ， 
如 CPU 等 。 但 主 存 总 是 从 设备 ,因为 它 不 会 主动 提出 要 与 谁 交换 信息 的 要 求 。 

注意 : 在 定义 总 线 数据 传送 操作 是 “输入 ”或 “输出 ”时 ,必须 以 主 设备 为 参考 点 , 即 从 设 
备 将 数据 送 往 主 设备 称 为 “输入 ”, 反 之 称 为 “输出 ”。 这 和 前 面 提 到 的 以 主机 为 参考 点 的 输 
入 、 输 出 的 含义 是 不 完全 相同 的 。 

通常 ,将 完成 一 次 总 线 操作 的 时 间 称 为 总 线 周 期 。 总 线 使 用 权 的 转让 发 生 在 总 线 进行 
一 次 数据 传送 的 结束 时 刻 。 在 一 个 总 线 周期 开始 时 ,对 CPU 或 1/O 设备 的 请 求 进行 取样 ， 
并 在 这 个 总 线 周 期 进行 数据 传送 的 同时 也 进行 判 优 ,选择 下 一 总 线 周 期 谁 能 获得 总 线 使 用 
权 , 然 后 在 本 周期 结束 时 实现 总 线 使 用 权 的 转移 ,开始 新 的 总 线 周期 。 


7.1.2 总 线 的 分 类 
1. 按 功能 层次 分 类 


总 线 按 功 能 层次 分 类 如 下 。 

(1) 片 内 总 线 

片 内 总 线 是 芯片 内 部 的 总 线 , 它 是 CPU 芯片 内 部 寄存 需 与 寄存 需 之 间 、 寄存 需 与 ALU 
之 间 的 公共 连接 线 。 片 内 总 线 在 心 片 内 部 ,一 般 是 看 不 见 的 。 


所 
沪 


(2) 系统 总 线 

系统 总 线 是 计算 机 系统 内 各 功能 部 件 (CPU、 主 存 .1/O 接口 ) 之 间 相互 连接 的 总 线 , 系 
统 总 线 也 称 为 内 总 线 ,是 构成 计算 机 的 主要 组 成 部 分 。 系 统 总 线 按 传 送 的 信息 不 同 可 以 分 
为 数据 总 线 、 地址 总 线 和 控制 总 线 。 

(3) 通信 总 线 ( 外 总 线 ) 

通信 总 线 是 用 于 计算 机 系统 之 间或 计算 机 系统 与 其 他 系统 (远程 通信 设备 、 测 试 设备 ) 
之 间 信 息 传送 的 总 线 。 例 如 ,一 个 计算 机 系统 和 男 一 个 计算 机 系统 ,或 者 计算 机 系统 与 远程 
通信 设备 或 测试 设备 之 间 的 信息 传送 就 通过 外 总 线 实现 。 


2. 按 数据 线 的 多 少 分 类 


按照 总 线 中 数据 线 的 多 少 不 同 ,总 线 又 可 分 为 以 下 几 类 ， 

(1) 并 行 总 线 

并 行 总 线 是 含有 多 条 双 回 数据 线 的 总 线 , 它 可 以 实现 一 个 数据 的 多 位 同时 传输 。 并 行 
总 线 具 有 数据 传输 率 高 的 优点 ,但 由 于 各 条 数据 线 的 传输 特性 不 可 能 完全 一 致 , 当 数 据 线 较 
长 时 ,数据 各 位 到 达 接 收 端 时 的 延迟 可 能 不 一 致 , 会 造成 传输 错误 。 

(2) 串 行 总 线 

串 行 总 线 是 只 含有 一 条 双 回 数据 线 或 两 条 单 问 数据 线 的 总 线 , 串 行 总 线 可 以 实现 一 个 
数据 的 各 位 按照 一 定 的 速度 和 顺序 依次 传输 。 巾 于 按 位 串 行 传输 数据 对 数据 线 传输 特性 的 
要 求 不 高 ,在 长 距离 连 线 情况 下 仍 可 以 有 效 地 传送 数据 ,所 以 串 行 总 线 的 优势 在 于 还 距离 
通信 。 


7.1.3 总 线 的 组 成 及 性 能 指标 
1. 总 线 结构 


在 单机 系统 中 ,从 系统 总 线 角 度 出 发 ,总 线 的 基本 结构 如 下 。 

@ 单 总 线 结构 : 只 有 一 条 系统 总 线 , 所 有 部 件 通过 系统 总 线 接 入 。 

@ 双 总 线 结构 : 在 单 总 线 的 基础 上 增加 一 条 专用 于 CPU 和 主 存 之 间 的 数据 传送 
通路 。 

@ 三 总 线 结构 : 在 双 总 线 的 基础 上 再 增加 一 条 I/O 总 线 。 

(1) 单 总 线 结构 

最 简单 的 总 线 结构 是 单 总 线 结构 ,如 图 1-3 所 示 。 各 大 部 件 都 连接 在 单一 的 一 组 总 线 
上 , 故 将 这 个 单 总 线 称 为 系统 总 线 。 

(2) 双 总 线 结构 

单 总 线 系统 中 各 部 件 只 能 分 时 工作 ,这 就 使 信息 传送 的 吞吐 量 受到 限制 ,为 此 设计 了 
图 7-2 所 示 的 双 总 线 系统 结构 。 这 种 结构 保持 了 单 总 线 系统 简单 .易于 扩充 的 优点 ,但 又 在 
CPU 和 主 存 之 间 专 门 设置 了 一 组 高 速 的 存储 总 线 , 使 CPU 可 通过 专用 总 线 与 存储 器 交换 
信息 ,减轻 了 系统 总 线 的 负担 。 

(3) 三 总 线 结构 

图 7-3 为 三 总 线 系统 的 结构 图 , 它 是 在 双 总 线 系统 的 基础 上 增加 1/O 总 线形 成 的 。 其 


EE 
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7-2 双 总 线 结构 


中 ,系统 总 线 是 CPU 、 主 存 和 通道 (IOP) 之 间 进 行 数据 传送 的 公共 通路 ,而 IO 总 线 是 多 个 
外 部 设备 与 通道 之 间 进 行 数 据 传送 的 公共 通路 。 


系统 总 线 
存储 总 线 
CPU 《一 主 存 储 器 
IO 总 线 


7-3 三 总 线 结 构 


2. 总 线 特 性 


通常 总 线 规范 中 会 详细 描述 总 线 各 方面 的 特性 。 

(1) 物理 特性 

物理 特性 又 称 机 械 特 性 , 它 规定 了 总 线 的 线 数 .总 线 的 插头 、 搬 座 的 形状 .尺寸 和 信号 线 
的 排列 方式 等 要 素 。 

(2) 功能 特性 

功能 特性 描述 总 线 中 每 一 根 线 的 功能 。 例 如 ,CPU 发 出 的 各 种 控制 命令 (如 存储 器 读 
写 .1/O 读 写 )、 外 设 与 主机 的 同步 匹配 信号 .中断 信号 和 DMA 控制 信号 等 。 

(3) 电气 特性 

电气 特性 定义 了 每 根 线 上 信和 号 的 传递 方向 及 有 效 电 平 范 围 。 

(4) 时 间 特 性 

时 间 特 性 规定 了 每 根 线 在 什么 时 间 有 效 , 以 及 不 同 信 号 之 间 相 互 配 合 的 时 间 关 系 。 只 
有 规定 了 总 线 上 各 信号 有 效 的 时 序 关 系 ,CPU 才能 正确 无 误 地 使 用 。 


3. 总 线 的 性 能 指标 
总 线 的 主要 性 能 指标 如 下 。 


Cm 


线 


(1) 总 线 宽度 

总 线 宽 度 指 的 是 总 线 的 线 数 , 它 决 定 了 总 线 所 占 的 物理 空间 和 成 本 。 对 总线 宽度 最 直 
接 的 影响 是 地 址 线 和 数据 线 的 数量 ,地 址 线 的 宽度 指明 了 总 线 能 直接 访问 存储 硕 的 地 址 空 
间 范 围 ,数据 线 的 宽度 指明 了 访问 一 次 存储 需 或 外 设 时 能 够 交换 的 数据 位 数 。 

(2) 总 线 带宽 

总 线 带宽 定义 为 总 线 的 最 大 数据 传输 率 , 即 每 秒 传输 的 字 节 数 。 在 同步 通信 中 ,总 线 的 
市 宽 与 总 线 时 钟 密 不 可 分 ,总 线 时 钟 频率 的 高 低 决 定 了 总 线 珊 宽 的 大 小 。 和 总 线 的 市 宽 公 
式 为 : 

B= WXF/N 

其 中 ,B 为 总 线 的 带宽 ;W 为 数据 总 线 宽度 ,通常 以 字 节 为 单位 ;下 为 总 线 的 时 钟 频率 ;NN 为 
完成 一 次 数据 传送 所 用 的 时 钟 周期 数 。 

(3) 总 线 负载 

总 线 负 载 指 连接 在 总 线 上 的 最 大 设备 数量 。 大 多 数 总 线 的 负载 能 力 是 有 限 的 。 

(4) 总 线 复 用 

总 线 分 时 复 用 是 指 在 不 同时 段 利用 总 线 上 同一 个 信号 线 传送 不 同 信号 ,例如 地 址 总 线 
和 数据 总 线 共 用 一 组 信号 线 。 采 用 这 种 方式 的 目的 是 减少 总 线 数量 ,提高 总 线 的 利用 率 。 

(5) 总 线 迎 发 传输 

狂 发 ( 突 发 ) 式 数据 传输 是 一 种 总 线 传输 方式 , 即 在 一 个 总 线 周期 中 可 以 传输 存储 地 址 
连续 的 多 个 数据 。 

除去 以 上 提 到 的 性 能 指标 外 ,如 总 线 是 否 具 有 即 插 即 用 功能 ,是 否 文 持 总 线 设 备 的 热 插 
拔 ,是 否 文 持 多 主 控 设 备 ,是 否 具 有 错误 检测 能 力 , 是 否 依赖 于 特定 CPU 等 也 是 评价 总 线 
性 能 的 指标 。 


7.2 总 线 仲 裁 


总 线 是 由 多 个 部 件 和 设备 所 共享 的 ,连接 到 总 线 上 的 功能 模块 有 主动 和 被 动 两 种 形态 ， 
CPU 可 以 作 主 方 也 可 以 作 从 方 ,而 存 取 融 模 块 只 能 用 作 从 方 。 为 了 保证 同一 时 刻 只 有 一 个 
申请 者 使 用 总 线 ,总 线 控制 机 构 中 设置 有 总 线 判 优 和 仲裁 控制 逻辑 , 即 按照 一 定 的 优先 次 序 
来 决定 哪个 部 件 首 先 使 用 总 线 , 只 有 获得 总 线 使 用 权 的 部 件 才 能 开始 数据 传送 。 总 线 判 优 
按 其 仲裁 控制 机 构 的 设置 可 分 为 集中 式 控 制 和 分 布 式 控制 两 种 。 


7.2.1 集中 仲裁 方式 


总 线 控制 逻辑 集中 在 一 处 (如 在 CPU 中 ) 的 称 为 集中 式 控制 ,就 集中 式 控 制 而 言 , 有 下 
面 3 种 常见 的 优先 权 仲 裁 方式 。 


1. 链 式 查询 方式 


链 式 查询 方式 如 图 7-4 所 示 ,总 线 控 制 硕 使 用 3 根 控制 线 与 所 有 部 件 和 设备 相连 ,而 
AB 和 DB 分 别 代 表 地 址 总 线 和 数据 总 线 。3 个 控制 信号 如 下 。 
总 线 请 求 CBR) : 该 线 有 效 , 则 表示 至 少 有 一 个 部 件 或 设备 要 求 使 用 总 线 。 
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中 


BS 
BR 4 | 
| | 
部 件 / 设 备 | | 部件 /设备 | 
] 
BG 


7-4” 链 式 查 询 方 式 


总 线 忙 (BS) : 该 线 有 效 , 则 表示 总 线 正 在 被 某 部 件 或 设备 使 用 。 

总 线 批 准 (BG) : 该 线 有 效 , 则 表示 总 线 控制 部 啊 应 总 线 请 求 。 

与 总 线 相连 的 所 有 部 件 经 公共 的 BR 线 发 出 总 线 请 求 ,只 有 在 BS 信号 未 建立 前 ,BR 才 
能 被 总 线 控制 器 啊 应 ,并 送出 BG 回答 信号 。BG 信号 串 行 地 通过 每 个 部 件 ,如 果 某 个 部 件 
本 号 没有 总 线 请 求 , 则 将 该 信号 传 给 下 一 个 部 件 ; 如果 这 个 部 件 有 总 线 请 求 ,就 停止 传送 
BG 信号 ,获得 总 线 使 用 权 。 这 时 该 部 件 将 建立 BS 信号 ,表示 它 占 用 了 总 线 ,并 撤销 总 线 请 
求 信号 BR ,进行 数据 的 传送 。BS 信号 在 数据 传送 完 后 撤销 ,BG 信号 也 随 之 撤销 。 

显然 , 链 式 查询 方式 的 优先 次 序 是 由 BG 线 上 串 接 部 件 的 先后 位 置 来 确定 的 ,在 查询 链 
中 离 总 线 控制 大 最 近 的 设备 具有 最 高 优先 权 。 

链 式 查询 的 优点 是 只 用 很 少 几 根 线 就 能 按 一 定 的 优先 次 序 来 实现 总 线 控制 ,并 很 容易 
实现 扩充 。 缺 点 是 对 查询 链 的 故障 很 敏感 ,如 果 第 ;个 部 件 中 的 查询 链 电 路 有 故障 ,那么 第 
i 个 以 后 的 部 件 都 不 能 工作 。 男 外 ,因为 查询 的 优先 级 是 固定 的 ,所 以 大 优先 级 较 高 的 部 件 
出 现 频 款 的 总 线 请 求 时 ,优先 级 较 低 的 部 件 就 可 能 会 难以 得 到 啊 应 。 


2. 计数 器 定时 查询 方式 


计数 副 定 时 查询 方式 如 图 7-5 所 示 ,总 线 上 的 每 个 部 件 可 以 通过 公共 的 BR 线 发 出 请 
求 , 总 线 控制 硕 收 到 请 求 之 后 ,在 BS 为 0 的 情况 下 ,让 计数 大 开始 计数 ,定时 地 查询 各 个 部 
件 以 确定 是 谁 发 出 的 请 求 。 当 查询 线 上 的 计数 值 与 发 出 请 求 的 部 件 号 一 致 时 ,该 部 件 就 使 
BS 线 置 1, 获 得 了 总 线 使 用 权 , 并 中 止 计数 查询 ,直至 该 部 件 完成 数据 传送 之 后 ,撤销 BS 
信和 号。 


EE 呈 本 国 国 国生 
总 ”| 定时 查询 计数 | | 
BS | || 

BR | | | 
J 


7-5 ”计数 器 定时 查询 方式 


这 种 计数 可 以 从 0 开始 ,也 可 以 从 中 止 点 开始 。 如 果 从 0 开始 ,各 部 件 的 优先 次 序 和 链 
式 查 询 方式 相同 ,优先 级 的 次 序 是 固定 的 。 如 果 从 中 止 点 开始 , 即 为 循环 优先 级 ,各 个 部 件 
使 用 总 线 的 机 会 将 相等 。 计 数 希 的 初始 值 还 可 以 由 程序 来 设置 ,这 就 可 以 方便 地 改变 优先 


地 - 
Fa 线 


次 序 ,增加 系统 的 灵活 性 。 定 时 查询 方式 的 控制 线 数 较 多 ,对 于 个 部 件 , 共 需 2 十 [logsn 眼 。 
3. 独立 请 求 方式 


独立 请 求 方式 如 图 7-6 所 示 ,在 这 种 方式 中 ,每 一 个 共享 总 线 的 部 件 均 有 一 对 控制 线 : 
总 线 请 求 BR; 和 总 线 批 准 BG; 。 当 茶 个 部 件 请 求 使 用 总 线 时 , 便 发 出 BR, ,总 线 控制 名 中 有 
一 排队 电路 ,根据 一 定 的 优先 次 序 决定 首先 啊 应 哪个 部 件 的 请 求 BR; ,然后 给 该 部 件 送 回 批 
准 信号 BG, 。 


n 


7-6 独立 请 求 方式 


独立 请 求 方式 的 优点 是 啊 应 时 间 快 ,然而 这 是 以 增加 控制 线 数 和 硬件 电路 为 代价 的 ,对 
于 ?7 个 部 件 ,控制 线 的 数目 将 达 2n 十 1 根 。 此 方式 对 优先 次 序 的 控制 也 是 相当 灵活 的 , 它 可 
以 预先 固定 ,也 可 以 通过 程序 来 改变 优先 次 序 。 


7.2.2 分 布 仲裁 方式 


分 布 仲裁 方式 不 震 要 中 央 仲 裁 融 , 即 总 线 控制 逻辑 分 散在 连接 于 总 线 上 的 各 个 部 件 或 
设备 中 。 连 接 到 总 线 上 的 主 方 可 以 启动 一 个 总 线 周期 ,而 从 方 只 能 啊 应 主 方 的 请 求 。 每 次 
总 线 操作 ,只 能 有 一 个 主 方 占用 和 总线 使 用 权 , 但 同一 时 间 里 可 以 有 一 个 或 多 个 从 方 。 对 多 个 
主 设备 提出 的 占用 总 线 请 求 ,一 般 采 用 优先 级 .冲突 检测 或 公平 策略 等 方法 进行 仲裁 。 其 
中 ,冲突 检测 仲裁 方式 一 般 用 在 网 络 通信 和 总 线 上 ,具体 来 说 就 是 “ 谈 前 先 听 ,冲突 重 发 ”, 主 方 
在 传输 前 ,会 侦 听 总 线 是 否 空 闪 , 耕 空 闪 则 立即 使 用 总 线 ; 在 传输 过 程 中 ,还 会 侦 听 总 线 是 否 
发 生 冲 突 , 右 发 生 冲 突 , 则 两 个 设备 都 会 停止 传输 ,延迟 一 个 随机 时 间 后 再 重新 使 用 总 线 。 


7.3 总线 定时 控制 
主机 与 外 设 通 过 总 线 进行 信息 交换 时 ,必然 存在 着 时 间 上 的 配合 和 动作 的 协调 问题 , 否 
则 系统 的 工作 将 出 现 混乱 。 总 线 的 定时 控制 方式 一 般 分 为 同步 方式 和 异步 方式 。 
7.3.1 同步 定时 方式 


所 谓 同步 定时 方式 ,是 指 系统 采用 一 个 统一 的 时 钟 信号 来 协调 发 送 和 接收 双方 的 传送 
定时 关系 。 时 钟 产 生 相 等 的 时 间 间 隔 ,每 个 间 隅 构成 一 个 总 线 周 期 。 在 一 个 总 线 周期 中 ,发 


加 
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送 和 接收 双方 可 以 进行 一 次 数据 传送 。 由 于 是 在 规定 的 时 间 段 内 进行 W/O 操作 ,所 以 发 送 
者 不 必 等 待 接收 者 有 什么 啊 应 , 当 这 个 时 间 段 结束 后 就 自动 进行 下 一 个 操作 。 

同步 方式 中 的 时 钟 频 率 必 须 能 适应 在 总 线 上 最 长 的 延迟 和 最 慢 的 接口 的 需要 。 因 此 ， 
同步 方式 的 效率 较 低 ,时 间 利 用 也 不 够 合理 ;同时 ,也 没有 办 法 知道 被 访问 的 外 设 是 否 已 经 
真正 地 啊 应 , 故 可 菲 性 比较 低 。 


7.3.2 异步 定时 方式 


异步 定时 方式 也 称 为 应 答 方式 。 在 这 种 方式 下 ,没有 公用 的 时 钟 ,也 没有 固定 的 时 间 间 
隔 , 完 全 依靠 传送 双方 相互 制约 的 “握手 ”信号 来 实现 定时 控制 。 

通常 ,把 交换 信息 的 两 个 部 件 或 设备 分 为 主 设备 和 从 设备 , 主 设 备 提出 交换 信息 的 “请 
求 ” 信 号 ,经 接口 传送 到 从 设备 ;从 设备 接 到 主 设备 的 申请 后 ,通过 接口 向 主 设备 发 出 “回答 ” 
信号 ,整个 “握手 ”过 程 就 是 在 一 问 一 答 中 进行 的 。 必 须 指 出 ,从 “请 求 ” 到 “回答 ”的 时 间 是 由 
操作 的 实际 时 间 决 定 的 ,而 不 是 由 CPU 的 节拍 硬性 规定 的 ,所 以 具有 很 强 的 灵活 性 ,而 且 
对 提高 整个 计算 机 系统 的 工作 效率 也 是 有 好 处 的 。 

异步 控制 能 保证 两 个 工作 速度 相差 很 大 的 部 件 或 设备 之 间 可 靠 地 进行 信息 交换 ,自动 
完成 时 间 的 配合 。 但 是 ,异步 控制 较 同 步 方式 稍 复杂 一 些 , 成 本 也 会 高 一 些 。 

异步 方式 根据 “请 求 > 和 ”回答 ”信号 的 撤销 是 否 互 锁 ,有 以 下 3 种 情况 。 

(1) 不 互 锁 

“请 求 ? 和 ”回答 ”信号 都 有 一 定 的 时 间 宽 度 ”请求 ” 信 号 的 结束 和 "回答 ?信号 的 结束 不 
互 锁 ,如 图 7-7(a) 所 示 。 

(2) 半 互 锁 

“请 求 ”* 信 号 的 撤销 取决 于 接收 到 “回答 ”信号 ,而 “回答 ”的 撤销 由 从 设备 自己 决定 ,如 
图 7-7(b) 所 示 。 

(3) 全 互 锁 

“请 求 ” 信 号 的 撤销 取决 于 “回答 ”信号 的 来 到 ,而 “请 求 ”* 信 号 的 撤销 又 导致 “回答 ”信号 
的 撤销 ,如 图 7-7(c) 所 示 。 全 互 锁 方式 给 出 了 最 高 的 灵活 性 和 可 靠 性 ,当然 也 付出 了 增加 接 
口 电路 复杂 性 的 代价 。 


请 求 请 求 请 求 
回答 回答 回答 
(a) (b) (C) 
7-7 ”请 求 与 回答 信号 的 互 锁 


7.4 总 线 标 准 


总 线 的 标准 制定 通常 有 两 种 途径 ,一 种 是 由 具有 权威 性 的 国际 标准 化 组 织 制定 并 推荐 
使 用 的 , 称 为 正式 标准 ; 男 一 种 是 由 茶 个 或 条 几 个 在 业界 具有 影 啊 力 的 设备 制造 商 提 出 ,而 
又 被 业内 其 他 厂家 认可 并 广泛 使 用 的 标准 , 即 所谓 的 事实 标准 ,这 些 标准 可 能 需要 经 过 一 段 
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时 间 的 使 用 ,被 厂商 提供 给 有 关 组 织 讨论 之 后 才能 成 为 正式 标准 。 
7.4.1 系统 总 线 标 准 


通常 ,微机 的 系统 总 线 都 做 成 多 个 插 模 的 形式 ,各 插 权 引 脚 通 过 总 线 连 在 一 起 。 总 线 接 
口 引 脚 的 定义 \ 传 输 速 率 的 设 定 、 驱 动能 力 的 限制 ,信号 电 平 的 规定 、 时 序 的 安排 以 及 信息 格 
式 的 约定 等 ,都 有 统一 的 标准 。 下 面 对 PC 系列 微机 的 总 线 标 准 进行 简要 介绍 。 


1. PC/XT 总 线 


PC/XT 总 线 是 早期 PC/XT 微机 所 配备 的 系统 总 线 , 是 8 位 总 线 标准 。PC/XT 总 线 共 
有 62 个 信号 ,是 目前 各 类 总 线 中 最 为 精简 的 。 
2.JISA 总 线 


ISA 总 线 最 早 用 于 PC/AT 机 ,因而 又 称 AT 总线 。 它 是 在 原 PC/XT 总 线 62 线 的 基 
础 上 又 增加 一 个 36 线 的 扩展 槽 ,成 为 16 位 的 总 线 标 准 , 即 工业 标准 体系 结构 (ISA) ,以 支 
持 8/16 位 的 数据 传送 和 24 位 寻 址 。 


3. MCA 总 线 


IBM 公司 于 1987 年 推出 了 32 位 微 通 道 结构 (MCA) 总 线 , 并 在 PS/2 机 上 使 用 。MCA 
总 线 的 数据 线 和 地 址 线 都 扩展 到 32 位 ,成 为 标准 的 32 位 扩展 总 线 系统 。 但 是 ,因为 MCA 
总 线 与 ISA 总 线 不 兼容 ,所 以 市 场 占有 率 不 高 。 


4. EISA 总 线 


1988 年 9 月 ,由 Compagq 和 AST 等 9 家 公司 联合 推出 了 一 种 既 与 ISA 兼容 ,又 在 许多 
方面 参考 了 MCA 设计 的 总 线 标准 , 称 为 增强 的 工业 标准 体系 结构 (EISA), 成 为 一 种 与 
MCA 相 抗 衡 的 总 线 标 准 。 


5. VL 总 线 (VESA 局 部 总 线 ) 


1992 年 5 月 ,视频 电子 标准 委员 会 (VESA) 制 定 了 VL 总 线 规范 。VL 总 线 的 数据 宽度 
为 32 位 ,其 主要 优点 是 : 协议 简单 .传输 速率 高 \ 能 够 文 持 多 种 便 件 的 工作 。 但 是 , 它 的 规 
范 性 .兼容 性 和 扩展 性 较 差 。 


6. PCI 局 部 总 线 


1991 年 下 半年 ,Intel 公司 首先 提出 了 PCI 总 线 的 概念 ,并 与 IBM、Compaq、AST 、HP 
和 DEC 等 公司 联合 ,于 1993 年 推出 PCI 总 线 。PCI 局 部 总 线 是 一 种 高 性 能 、32 位 或 64 位 
地 址 数据 线 复 用 的 总 线 , 它 的 兼容 性 好 ,不 受 CPU 品种 的 限制 。 


7. AGP 


AGP( 图 形 加 速 端口 ) 是 由 Intel 创建 的 新 总 线 ,专门 用 作 高 性 能 图 形 及 视频 支持 。 
AGP 基于 PCI, 且 AGP 插 柳 外 形 与 PCI 类 似 , 但 它 有 增加 的 信号 ,同时 在 系统 中 的 定位 不 
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同 ,是 专门 为 系统 中 的 视频 卡 设计 的 。 
8. PCI-Express 


PCI-Express(PCI-E) 是 最 新 的 总 线 和 接口 标准 ,以 取代 几乎 全 部 现 有 的 内 部 总 线 (包括 
AGP 和 PCD ,最 终 实 现 总 线 标准 的 统一 。 它 的 主要 优势 就 是 数据 传输 速率 高 ,目前 可 高 达 
10GB/s 以 上 ,而 且 还 有 相当 大 的 发 展 潜力 。PCI-E 有 1X 到 32X 等 多 种 规格 ,具有 非常 强 
的 伸缩 性 ,能 满足 现在 和 将 来 一 定时 间 内 出 现 的 低速 设备 和 高 速 设备 的 需求 。PCI-E 16X 
用 于 取代 目前 的 AGP 接口 ,PCI-E 1X、2X 用 于 取代 目前 的 CPI 接口 ,而 针对 服务 器 上 的 设 
备 则 有 PCI-E 4X、8X、12X 等 。 

PCI-E 采用 彻底 的 串 行 传输 模式 代替 传统 设备 之 间 的 并 行 传输 模式 ,一 个 PCI-E 串 行 
连接 称 为 lane, 由 两 对 单 向 传输 的 导线 组 成 ,一 对 负责 发 送 ,一 对 负责 接收 ,每 个 周期 虽然 只 
传输 1 位 信息 ,但 它 是 以 高 达 2. 5Gb/s 的 速度 传输 。 一 个 PCI-E 可 以 由 多 个 lane 组 成 , 标 
志 为 1 X、2X 等 数字 就 是 指 有 效 的 lane 的 总 数 。PCI-E 1X 只 需 有 4 条 线 连接 ,16X 则 需要 
它 的 16 倍 即 64 条 线 连接 ,所 以 PCI-E 16X 插 权 要 比 PCI-E 1X 插 权 长 得 多 。 可 以 将 PCI-E 
1X 的 卡 插 在 PCI-E 16X 的 插 模 上 (当然 它 依然 只 能 工作 在 1X 的 速度 下 ) ,但 不 能 把 PCIL-E 
16X 的 卡 插 在 PCI 1X 的 插 模 上 ，。 

PCI-E 1.0 发 表 于 2002 年 ,传输 速率 为 2. 5GT/s;PCI-E 2. 0 则 更 进 了 一 步 , 传 输 速率 
提升 到 了 5GT/s;PCI-E 3. 0 将 传输 速率 提升 到 8GT/s, 并 保持 了 对 PCI-E 1.0/2.0 的 向 下 
兼容 ,继续 文 持 2. 5GHz、5GHz 信号 机 制 。 目前, PCI-E 4. 0 已 经 面市 ,传输 速率 达到 
16GT/s。PCI-E 5.0 的 规范 也 已 出 台 。PCI-E 规范 的 发 展 如 表 7-1 所 示 。 


表 7-1 PCI-E 规范 的 发 展 


带 寓 
ee | 

PCI-E 1.0/2.0 之 所 以 数据 传输 率 与 原始 传输 率 有 差别 ,是 因为 它们 采用 的 是 8b/10b 
编 解码 机 制 ;而 PCI-E 3.0 开始 引入 了 128b/130b 机 制 ,可 以 确保 几乎 100% 的 传输 效率 ， 
相 比 此 前 版 本 提升 了 25% ,从 而 促成 了 传输 带宽 的 翻番 。 

需要 说 明 的 是 ,采用 8b/10b 机 制 可 使 得 发 送 的 0、1 数量 保持 基本 一 致 ,以 保证 直流 平 
衡 , 即 连续 的 1 或 0 不 超过 5 位 ,( 每 5 个 连续 的 1 或 0 后 必须 插入 一 位 0 或 1)。 换 句 话 说 ， 
8b/10b 解码 是 将 1 组 10 位 的 输入 数据 经 过 变换 得 到 8 位 数据 位 , 即 占用 了 20% 的 总 带宽 。 
通过 8b/10b 机 制 , 可 以 保证 传输 的 数据 串 在 接收 端 能 够 被 正确 复原 。8b/10b 是 目前 许多 
高 速 串 行 总 线 采 用 的 编码 机 制 ,例如 USB 3.0 IEEE 1394b、SATA、PCI-E 1.0/2.0 等 。 
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7.4.2 外 部 总 线 标 准 


外 总 线 是 计算 机 系统 之 间 互 连 的 总 线 , 通 第 使 用 标准 的 接口 插头 ,其 结构 和 通信 规约 也 
是 标准 的 。 


1. 串口 和 并 口 


串口 又 称 通信 口 或 COM 端口 ,主要 用 于 需要 与 系统 进行 双向 通信 的 设备 。 这 些 设备 
包括 早期 的 调制 解 调 器 、 鼠 标 、 扫 描 仪 ,以 及 所 有 问 计 算 机 发 送信 息 和 从 计算 机 接收 信息 的 
其 他 设备 。 

传统 的 串口 是 异步 传送 , 且 面 向 字符 的 , 它 上 具有 20% 的 额外 信息 开销 ,这 些 信息 是 标识 
每 个 字符 所 需 的。 每 个 通过 串 行 连 接 发 送 的 字符 都 是 由 一 个 标准 的 起 止 信 号 来 形成 数据 帧 
的 ,在 每 个 字符 前 是 一 个 独立 的 二 进 制 “0”( 称 为 起 始 位 ) ,随后 的 8 个 二 进 制 数 字 将 组 成 数 
据 的 一 个 字 节 。 在 字符 后 跟 有 1 个 或 2 个 二 进 制 “1”( 称 为 停止 位 ) 。 在 通信 的 接收 端 ,对 字 
符 的 识别 是 利用 起 止 信 号 ,而 不 是 根据 字符 到 达 的 时 间 来 进行 。 图 7-8 表示 字符 数据 的 串 
行 格式 ,7 位 ASCII 码 连续 传送 ,由 最 低 有 效 数 字 位 开始 ,而 以 奇偶 校 验 位 结束 ,起 始 位 为 低 
电 平 ,停止 位 为 高 电 平 。 
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7-8 ASCII 码 的 串 行 格式 


所 有 串口 的 核心 是 通用 异步 收发 器 (CUART) 芯 片 , 该 芯片 可 以 实现 将 计算 机 输出 的 并 
行 数据 转换 成 串 行 格式 ,或 者 将 串 行 数据 转换 成 并 行 格式 送 回 计算 机 的 过 程 。 当 通信 对 象 
远离 主机 时 ,采用 串 行 传送 方式 更 经 济 、 有 效 。RS-232 或 RS-422 等 串 行 总 线 标准 在 计算 机 
终端 中 广泛 采用 。 

并 口 一 般 用 于 将 打印 机 等 设备 连接 到 计算 机 上 。 并 口 之 所 以 被 称 为 并 口 ,是 因为 它 有 
8 条 数据 线 , 可 以 通过 这 8 条 数据 线 同 时 发 送 包含 数据 的 一 个 字 节 的 所 有 数据 位 。 

IEEE 1284 标准 定义 了 并 口 的 物理 特性 ,标准 中 给 出 了 5 种 不 同 的 并 口 操作 模式 ,如 
表 7-2 所 示 。 


表 7-2 IEEE 1284 并 口 模式 


pr 50KB/s 

字 节 (8 位 ) 150KB/s 

兼容 150KB/s 
EPP( 增 强 型 并 口 ) 500KB/s~2MB/s 
ECP( 扩 充 能 力 端口 ) 500KB/s~2MB/s 


早期 计算 机 的 并 口 仅 能 用 来 将 信息 从 计算 机 发 送 到 设备 (输出 )。 后 来 出 现 的 标准 并 口 
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能 实现 8 位 输出 ( 称 为 兼容 模式 ) 和 4 位 输入 ( 称 为 半 字 节 模 式 ) ,标准 并 口 的 有 效 传输 率 是 : 
输出 150KB/s, 输 入 50KB/s。 目 前 的 计算 机 系统 , 则 往往 带 有 功能 更 强大 的 并 行 接口 ,例如 
双向 并 口 .EPP 或 ECP。 双 向 并 口 使 用 标准 的 8 位 数据 线 可 以 实现 8 位 输入 和 8 位 输出 ， 
且 都 能 达到 150KB/s 的 传输 率 。EPP 或 ECP 被 称 为 高 速 并 口 ,它们 可 以 获得 2MB/s 的 传 
输 率 ,可 以 用 来 支持 诸如 Zip 驱动 器 .CD-ROM 驱动 器 ,扫描 仪 .磁带 机 ,甚至 硬盘 等 外 设 。 

由 传统 的 串口 ,并口 完成 的 功能 现在 已 经 越 来 越 多 地 由 新 的 接口 类 型 完成 了 。 例 如 ,高 
速 串 行 总 线 USB 和 IEEE-1394 都 是 远 胜 于 标准 串口 和 并 口 性 能 的 高 速 通信 接口 ,可 以 用 
来 实现 与 高 速 外 设 的 连接 。 

最 新 的 高 性 能 外 部 总 线 设 计 的 趋势 是 使 用 串 行 结构 ,这 样 可 以 通过 一 根 导线 一 次 发 
送 一 位 数据 。 而 并 行 结构 则 需要 同时 使 用 8 根 、16 根 或 更 多 的 导线 来 发 送 数据 位 。 在 相 
同 的 时 钟 速度 下 ,并 行 总 线 要 快 得 多 。 但 是 ,提高 并 行 连 接 的 时 钟 速度 却 要 比 提高 串 行 
连接 的 时 钟 速度 难得 多 ,这 是 因为 虽然 8 位 数据 被 发 送 吕 同时 发 送 , 但 由 于 传输 延迟 的 
原因 , 当 它 们 到 达 接 收 需 时 ,可 能 会 有 一 些 数据 位 先 于 其 他 数据 位 到 达 。 随 着 导线 的 延 
长 ,这 种 信号 的 不 同步 将 会 更 严重 ,这 使 得 数据 不 能 以 高 的 传输 速率 来 进行 传送 。 而 使 
用 串 行 总 线 由 于 一 次 仅 发 送 一 位 数据 ,无 须 担 心 每 一 位 数据 的 到 达 时 间 , 因 而 可 以 极 大 
地 提高 时 钟 频 率 。 另 外 ,在 高 时 钟 频 率 下 ,并 行 传输 的 数据 线 之 间 将 相互 干扰 ,而 串 行 传 
输 可 以 忽略 这 一 干扰 。 


2. USB 接口 


USB( 通 用 串 行 总 线 ) 是 一 种 外 设 总 线 标准 , 它 的 设计 为 计算 机 的 外 设 市 来 了 即 插 即 用 
功能 。USB 的 出 现 不 再 需要 专用 的 端口 ,也 减少 了 1/O 卡 的 使 用 (从 而 也 减少 了 因 添 加 新 
卡 而 重新 配置 系统 的 需要 ) ,大 大 节省 了 重要 的 系统 资源 。 带 有 USB 的 计算 机 可 以 支持 对 
外 设 的 自动 识别 与 设置 ,只 需要 将 外 设 在 物理 上 连接 到 计算 机 即 可 ,而 不 需要 重新 启动 或 运 
行 安装 程序 。USB 在 一 台 计 算 机 上 最 多 可 以 同时 支持 127 台 设 备 的 运行 。 

USB 给 所 有 连接 的 设备 提供 电源 ,并 文 持 热 插 拔 ,这 意味 不 需要 关 挥 计算 机 或 重新 局 
动 系统 就 可 以 动态 地 插 接 设备 。 

过 去 主板 中 主要 采用 USB 1.1 和 USB 2.0, 而 目前 的 主板 中 主要 采用 USB 2. 0 和 
USB 3.0。 各 USB 版 本 间 能 很 好 地 兼容 。USB 1. 1 版 以 12Mb/s(1. 5MB/s) 的 速率 运行 ， 
由 于 所 有 的 设备 只 能 共享 1. 5MB/s 的 带宽 ,这 就 意味 着 每 增加 一 台 活 动 的 设备 ,总 线 就 将 
慢 一 些 。USB 2.0 是 USB 1. 1 的 扩展 ,所 有 USB 1. 1 设备 都 可 以 在 USB 2.0 总 线 上 工作 。 
USB 3. 1 是 最 新 的 USB 规范 , 它 向 下 兼容 USB 1.1、USB 2.0 和 USB 3. 0 标准 。USB 3.0 
和 USB 3. 1 都 采用 了 9 针脚 设计 ,其 中 4 个 针脚 和 USB 2.0 的 形状 .定义 均 完 全 相同 。 
USB 各 版 本 的 传输 率 如 表 7-3 所 示 。 


表 7-3 USB 的 传输 率 


版 本 号 最 大 传输 速率 最 大 输出 电流 编码 
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USB 2. 0 基于 半 双 工 二 线 制 总 线 , 只 能 提供 单 问 数据 流传 输 ,而 USB 3. 0 采用 了 四 线 
制 差 分 信号 线 ,故而 支持 双 加 并 发 数据 流传 输 。 此 外 ,USB 3.0 引入 了 新 的 电源 管理 机 制 ， 
支持 待机 、 休 虐 和 暂停 等 状态 。USB 3. 1 还 分 出 Genl 和 Gen2 ,所 谓 USB 3.1 Gen 1 实际 
上 就 是 原来 的 USB 3.0, 真 正 的 新 标准 是 USB 3. 1 Gen 2。 

USB 是 迄今 为 止 最 通用 的 外 部 接口 ,可 以 连接 鼠标 、 键 盘 、 打印 机 、 扫 摘 仪 摄像头、 内 
存盘 . 手机、 数码 相机 、 移 动 便 盘 、 外 置 光 驱 `\USB 网 卡 等 几乎 所 有 的 外 部 设备 。 


3. IEEE 1394 接口 


IEEE 1394 也 被 称 为 i. Link 或 Fire Wire, 同 USB 一 样 ,IEEE 1394 支持 外 设 热 搬 拔 ， 
并 为 外 设 提供 电源 。IEEE 1394 的 最 初版 本 被 称 为 1394a ,传输 速率 为 100Mb/s、200Mbys、 
400Mb/s, 其 升级 版 本 1394b 能 提供 800 Mb/s 或 更 高 的 传输 速度 ,甚至 有 望 文 持 1600Mb/s 和 
3200Mbys 的 传输 速率 。IEEE 1394 构建 在 菊花 链 或 树 状 的 拓扑 结构 上 的 , 它 文 持 多 达 63 
台 设 备 。 另 外 ,与 SCSI 一 样 ,IEEE 1394 能 够 在 同一 条 总 线 上 支持 不 同 速率 的 设备 。 

相 比 于 USB 接口 ,在 USB 1.1 时 代 ,1394a 接口 在 速度 上 还 是 占据 了 很 大 优势 的 ,但 在 
USB 2.0 推出 后 ,1394a 接口 在 速度 上 的 优势 就 不 下 明显 了。 同时 ,现在 绝对 多 数 主 流 的 计 
算 机 并 没有 配置 1394 接口 ,要 使 用 必须 要 购买 相关 的 接口 卡 。 但 是 ,IEEE 1394 仍然 有 一 
定 的 市 场 , 这 是 因为 它 的 一 个 重要 优点 是 不 要 求 连接 微机 ,可 以 用 来 直接 将 数字 视频 (DV) 
摄像 机 连接 到 DV-VCR 进行 磁带 复制 或 编辑 。 


4. eSATA 接口 


eSATA 的 全 称 是 External Serial AIA (外 部 串 行 AIA ) , 它 是 SATA 接口 ( 详 见 8.3.4 节 
介绍 ) 的 外 部 扩展 规范 。 换 言 之 ,eSATA 就 是 "外 置 ? 版 的 SATA, 它 是 用 来 连接 外 部 而 非 
内 部 SATA 设备 。 例 如 ,拥有 eSATA 接口 ,就 可 以 轻松 地 将 SATA 硬盘 与 主板 的 eSATA 
接口 连接 ,而 不 用 打开 机 箱 更 换 SATA 硬盘 。 

eSATA 拥有 极 大 的 传输 速度 优势 。 例 如 , USB 2.0 的 数据 传输 率 可 以 达到 60MB/s， 
IEEE 1394 的 数据 传输 率 可 以 达到 50 一 100MB/s,eSATA 最 高 却 可 提供 384MB/s(3Gb/s) 
的 数据 传输 速度 , 远 远 高 于 USB 2.0 和 IEEE 1394。 在 实际 应 用 上 , 受 硬盘 内 部 传输 率 及 
主板 的 制约 ,实际 数据 传输 率 可 能 介 于 1. 5Gb/s 一 3Gby/s 之 间 , 但 仍 高 于 USB 2.0 和 IEEE 
1394 的 传输 速率 ,并 且 依 然 保 持 方 便 的 热 插 拔 功 能 ,用 户 不 需要 关机 便 能 随时 接 上 或 移 除 
SATA 装置 ,十 分 方便 。 

eSATA 是 伴随 SATA 接口 衍生 出 来 的 新 一 代 外 置 设 备 接口 ,在 USB 3.0 没有 出 现 
之 前 ,eSATA 接口 的 传输 速度 相 比 USB 2.0 有 着 绝对 的 优势 ,而 随 着 USB 3. 0 接口 的 普 


7 
章 
229 


计算 机 组 成 原理 (第 4 版 ) 


及 ,eSATA 接口 遇 到 了 挑战 。 目 前 来 看 ,eSATA 与 USB 3. 0 接口 在 速度 上 不 相 上 下 ,但 
eSATA 只 拥有 传输 数据 的 功能 ,并 不 能 够 给 设备 供电 ,而 USB 3.0 则 完全 不 存在 这 个 问 
题 。 当 然 USB 3.0 也 有 它 的 劣势 , 即 要 将 硬盘 中 的 数据 通过 USB 3.0 接口 传输 , 则 必须 
拥有 桥接 芯片 ,而 这 个 芯片 则 可 能 在 传输 数据 的 过 程 中 消耗 传输 速度 。 从 各 种 因素 以 及 
今后 的 发 展 趋势 来 看 ,也许 未 来 USB 3. 0 接口 会 越 来 越 强势 ,而 eSATA 接口 很 有 可 能 成 
为 历史 。 


习 十 


7-1 假设 地 址 线 有 20 位 ,允许 寻 址 的 主 存 空 间 有 多 大 ? 假设 地 址 线 有 32 位 ,允许 寻 址 的 主 存 空间 又 
有 多 大 ? 

7-2 ”假设 总 线 的 工作 频率 为 22MHz, 总 线 宽 度 为 16 位 , 问 总 线 带 宽 是 多 少 ? 

7-3 PCI 总 线 的 时 钟 频 率 为 33MHz/66MHz, 当 该 总 线 进 行 32/64 位 数据 传送 时 ,总 线 带宽 各 是 
多 少 ? 

7-4 假定 某 同 步 总 线 在 一 个 时 钟 周期 内 传送 一 个 4 字 节 的 数据 ,总 线 时 钟 频率 为 33MHz, 求 总 线 带 
宽 是 多 少 ? 如 果 数 据 总 线 宽 度 改 为 64 位 ,一 个 时 钟 周 期 能 传送 2 次 数据 ,总线 时 钟 频率 为 66MHz, 则 总 线 
带宽 为 多 少 ? 提高 了 多 少 倍 ? 

7-5 分析 哪些 因素 影响 带宽 。 

7-6 某 总 线 时 钟 频 率 为 66MHz, 在 一 个 64 位 总 线 中 ,总 线 数据 传输 的 周期 是 7 个 时 钟 周期 传输 6 个 
字 的 数据 块 。 

(1) 问 总 线 的 数据 传输 率 是 多 少 ? 

(2) 如 果 不 改变 数据 块 的 大 小 ,而 是 将 时 钟 频率 减 半 , 问 这 时 总 线 的 数据 传输 率 是 多 少 ? 

7-7 为 什么 要 设立 总 线 仲 裁 机 构 ? 集中 式 总 线 控制 常用 哪些 方式 ? 它们 各 有 什么 优 缺 点 ? 

7-8 ”总 线 的 同步 通信 和 异步 通信 有 何不 同 ? 试 举例 说 明 一 次 全 互 锁 异 步 应 答 的 通信 和 情况。 


第 萤 
四 0 外 部 设备 


外 部 设备 是 计算 机 系统 中 不 可 缺少 的 重要 组 成 部 分 ,本 草 将 介绍 磁 介 质 存储 副 的 存储 
原理 ,和 背 用 磁 介 质 存储 设备 和 其 他 辅助 存储 设备 以 及 篆 见 的 输入 输出 设备 的 工作 原理 。 


8.1 外 部 设备 概述 


中 央 处 理 右 (CPU) 和 主 存 储 右 (MM) 构 成 计算 机 的 主机 。 除 主机 以 外 ,而 又 围绕 着 主 
机 设置 的 各 种 人 硬件 装置 称 为 外 部 设备 或 外 围 设备 。 它 们 主要 用 来 完成 数据 的 输入 输出 成 
批 存 储 以 及 对 信息 加 工 处 理 的 任务 。 
8.1.1 外 部 设备 的 分 类 

外 部 设备 的 种 类 很 多 ,从 它们 的 功能 及 其 在 计算 机 系统 中 的 作用 来 看 ,可 以 分 为 以 下 
4 类 。 

1. 输入 输出 设备 

从 计算 机 的 角度 出 发 ,向 计算 机 输入 信息 的 外 部 设备 称 为 输入 设备 ;接收 计算 机 输出 信 
上 县 的 外 部 设备 称 为 输出 设备 。 

输入 设备 有 键盘 .鼠标 .扫描 需 数字 化 仪 、 磁 卡 输 入 设备 .语音 输入 设备 等 。 输 出 设备 


有 显示 设备 、 绘 图 机 、 打 印 输出 设备 等 。 
男 外 ,还 有 一 些 羔 有 输入 和 输出 功能 的 复合 型 输入 输出 设备 。 


2. 辅助 存储 器 


辅助 存储 融 是 指 主机 以 外 的 存储 交 置 ,又 称 后 援 存 储 融 。 辅 助 存储 融 的 谈 写 ,就 其 本 质 
来 说 也 是 输入 或 输出 ,所 以 可 以 认为 辅助 存储 部 也 是 一 种 复合 型 的 输入 输出 设备 。 
目前 ,第 见 的 辅助 存储 大 有 便 磁盘 存储 名、 磁带 存储 融 及 光盘 存储 天 等 。 


3. 终端 设备 


终端 设备 由 输入 设备 、 输 出 设备 和 终端 控制 带 组 成 ,通常 通过 通信 线路 与 主机 相连 。 终 
端 设备 具有 疝 计 算 机 输入 信息 和 接收 计算 机 输出 信息 的 能 力 ,具有 与 通信 线路 连接 的 通信 
控制 能 力 , 有 些 还 具有 一 定 的 数据 处 理 能 力 。 
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终端 设备 一 般 分 为 通用 终端 设备 和 专用 终 端 设备 两 大 类 。 专 用 终 问 设 备 是 指 专 门 用 于 
某 一 领域 的 终端 设备 ;通用 终端 设备 则 适用 于 各 个 领域 , 它 又 可 分 为 会 话 型 终端 还 地 批 处 
理 终端 和 智能 终端 。 


4. 过 程控 制 设备 


当 计 算 机 进行 实时 控制 时 ,需要 从 控制 对 象 取得 参数 ,而 这 些 原始 参数 大 多 数 是 模拟 
量 ,需要 先 用 模 数 转换 天 将 模拟 量 转换 为 数字 量 ,然后 再 输入 计算 机 进行 处 理 。 而 经 计算 机 
处 理 后 的 控制 信息 , 需 先 经 数 模 转 换 天 把 数字 量 转 换 成 模拟 量 ,再 送 到 执行 部 件 对 控制 对 旬 
进行 上 月 动 调节 。 模 数 转 换 、 数 模 转 换 设备 均 是 过 程控 制 设备 ,有 关 的 检测 设备 也 属于 过 程控 
制 设 备 。 


8.1.2 外 部 设备 的 地 位 和 作用 


外 部 设备 是 计算 机 和 外 界 联系 的 纽带 .接口 和 界面 ,如 果 没 有 外 部 设备 ,计算 机 将 无 法 
工作 。 随 看 超大 规模 集成 电路 技术 的 发 展 ,主机 的 造价 越 来 越 低 , 而 外 部 设备 的 价格 在 计算 
机 系统 中 所 占 的 比例 越 来 越 高 。 由 此 可 见 , 外 部 设备 在 计算 机 系统 中 占据 的 地 位 变 得 越 来 
越 重 要 了 。 

外 部 设备 在 计算 机 系统 中 的 作用 可 以 分 为 4 个 方面 。 


1. 外 部 设备 是 人 机 对 话 的 通道 


无 论 是 微型 计算 机 系统 ,还 是 小 、 中 、 大 型 计算 机 系统 ,要 把 数据 、 程 序 送 入 计算 机 或 要 
把 计算 机 的 计算 结果 及 各 种 信息 送出 来 ,都 要 通过 外 部 设备 来 实现 。 因 此 ,外 部 设备 成 为 人 
机 对 话 的 通道 。 


2. 外 部 设备 是 完成 数据 媒体 变换 的 设备 


人 们 习惯 用 字符 、 汉字 图形 .图 像 等 来 表达 信息 的 含义 ,而 计算 机 内 部 却 是 以 电信 号 表 
示 的 二 进 制 代码 。 因 此 ,在 人 机 对 话 交 换 信息 时 ,首先 需要 将 各 种 信息 变 成 计算 机 能 识别 的 
二 进 制 代码 形式 ,然后 再 输入 计算 机 ;同样 ,计算 机 处 理 的 结果 也 必须 变换 成 人 们 所 熟悉 的 
表示 方式 ,这 两 种 变换 只 能 通过 外 部 设备 来 实现 。 


3. 外 部 设备 是 计算 机 系统 软件 和 信息 的 驻 在 地 


随 者 计算 机 技术 的 发 展 ,系统 软件 数据 库 和 竺 处 理 的 信息 量 越 来 越 大 ,不 可 能 全 部 存 
放 在 主 存 中 ,因此 ,以 磁盘 存储 天 或 光盘 人 存储 天 为 代表 的 辅助 存储 天 已 成 为 系统 软件 、 数 据 
库 及 各 种 信息 的 驻 在 地 。 


4. 外 部 设备 是 计算 机 在 各 领域 应 用 的 桥梁 


随 着 计算 机 应 用 范围 的 扩大 ,已 从 早期 的 数值 计算 扩展 到 文字 、 表 格 、 图 形 、 图 像 和 
语音 等 非 数 值 信息 的 处 理 。 为 了 适应 这 些 处 理 , 各 种 新 型 的 外 部 设备 陆续 被 制造 出 来 。 
无 论 哪个 领域 .哪个 部 门 ,只 有 配置 了 相应 的 外 部 设备 ,才能 使 计算 机 在 这 些 方面 获得 广 
沁 的 应 用 。 
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终端 设备 一 般 分 为 通用 终端 设备 和 专用 终 端 设备 两 大 类 。 专 用 终 问 设 备 是 指 专 门 用 于 
某 一 领域 的 终端 设备 ;通用 终端 设备 则 适用 于 各 个 领域 , 它 又 可 分 为 会 话 型 终端 还 地 批 处 
理 终端 和 智能 终端 。 


4. 过 程控 制 设备 


当 计 算 机 进行 实时 控制 时 ,需要 从 控制 对 象 取得 参数 ,而 这 些 原始 参数 大 多 数 是 模拟 
量 ,需要 先 用 模 数 转换 天 将 模拟 量 转换 为 数字 量 ,然后 再 输入 计算 机 进行 处 理 。 而 经 计算 机 
处 理 后 的 控制 信息 , 需 先 经 数 模 转 换 天 把 数字 量 转 换 成 模拟 量 ,再 送 到 执行 部 件 对 控制 对 旬 
进行 上 月 动 调节 。 模 数 转 换 、 数 模 转 换 设备 均 是 过 程控 制 设备 ,有 关 的 检测 设备 也 属于 过 程控 
制 设 备 。 


8.1.2 外 部 设备 的 地 位 和 作用 


外 部 设备 是 计算 机 和 外 界 联系 的 纽带 .接口 和 界面 ,如 果 没 有 外 部 设备 ,计算 机 将 无 法 
工作 。 随 看 超大 规模 集成 电路 技术 的 发 展 ,主机 的 造价 越 来 越 低 , 而 外 部 设备 的 价格 在 计算 
机 系统 中 所 占 的 比例 越 来 越 高 。 由 此 可 见 , 外 部 设备 在 计算 机 系统 中 占据 的 地 位 变 得 越 来 
越 重 要 了 。 

外 部 设备 在 计算 机 系统 中 的 作用 可 以 分 为 4 个 方面 。 


1. 外 部 设备 是 人 机 对 话 的 通道 


无 论 是 微型 计算 机 系统 ,还 是 小 、 中 、 大 型 计算 机 系统 ,要 把 数据 、 程 序 送 入 计算 机 或 要 
把 计算 机 的 计算 结果 及 各 种 信息 送出 来 ,都 要 通过 外 部 设备 来 实现 。 因 此 ,外 部 设备 成 为 人 
机 对 话 的 通道 。 


2. 外 部 设备 是 完成 数据 媒体 变换 的 设备 


人 们 习惯 用 字符 、 汉字 图形 .图 像 等 来 表达 信息 的 含义 ,而 计算 机 内 部 却 是 以 电信 号 表 
示 的 二 进 制 代码 。 因 此 ,在 人 机 对 话 交 换 信息 时 ,首先 需要 将 各 种 信息 变 成 计算 机 能 识别 的 
二 进 制 代码 形式 ,然后 再 输入 计算 机 ;同样 ,计算 机 处 理 的 结果 也 必须 变换 成 人 们 所 熟悉 的 
表示 方式 ,这 两 种 变换 只 能 通过 外 部 设备 来 实现 。 


3. 外 部 设备 是 计算 机 系统 软件 和 信息 的 驻 在 地 


随 者 计算 机 技术 的 发 展 ,系统 软件 数据 库 和 竺 处 理 的 信息 量 越 来 越 大 ,不 可 能 全 部 存 
放 在 主 存 中 ,因此 ,以 磁盘 存储 天 或 光盘 人 存储 天 为 代表 的 辅助 存储 天 已 成 为 系统 软件 、 数 据 
库 及 各 种 信息 的 驻 在 地 。 


4. 外 部 设备 是 计算 机 在 各 领域 应 用 的 桥梁 


随 着 计算 机 应 用 范围 的 扩大 ,已 从 早期 的 数值 计算 扩展 到 文字 、 表 格 、 图 形 、 图 像 和 
语音 等 非 数 值 信息 的 处 理 。 为 了 适应 这 些 处 理 , 各 种 新 型 的 外 部 设备 陆续 被 制造 出 来 。 
无 论 哪个 领域 .哪个 部 门 ,只 有 配置 了 相应 的 外 部 设备 ,才能 使 计算 机 在 这 些 方面 获得 广 
沁 的 应 用 。 
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3. 读 出 过 程 


读 出 时 , 读 磁 头 线圈 不 外 加 电流 。 当 某 一 磁化 单元 运动 到 读 磁 头 下 方 时 ,使 得 磁头 中 流 
过 的 人 磁 通 有 很 大 的 变化 ,于 是 在 读 磁 头 线圈 两 端 产生 感应 电动 势 e。 
ecc— dy 
dt 


e 的 极 性 与 磁 通 变化 的 极 性 相反 。 当 磁 通 $ 由 小 到 大 变化 时 ,在 读 磁头 线圈 中 感应 产 
生 一 个 负 脉 冲 ; 当 磁 通 8 由 大 到 小 变化 时 , 则 感应 产生 一 个 正 脉冲 。 上 述 脉 冲 信 号 经 放大 、 
检 波 \ 限 幅 、 整 形 和 选 通 后 ,获得 符合 要 求 的 信号 。 


8.2.2 磁 介 质 存 储 器 的 技术 指标 
衡量 磁 介 质 存 储 器 的 主要 技术 指标 有 下 述 几 种 。 
1. 记录 密度 


记录 密度 又 称 存 储 密度 ,是 指 磁 介 质 存 储 大 上 单位 长 度 或 单位 面积 所 存储 的 二 进 制 信 
息 量 。 通 常 以 道 密度 和 位 密度 表示 ,也 可 用 两 者 的 乘积 一 一 面 密 度 来 表示 。 

(1) 道 密度 

道 密度 又 称 横 回 密度 ,是 指 垂 百 于 磁道 方向 上 单位 长 度 中 的 磁 关 数目 ,着 密度 的 单位 是 
道 /in(Tracks Per Inch,TPI) 或 道 /mm(CTracks Per Millimeter, TPM)， 

磁道 指 的 是 磁头 写 人 磁场 在 记录 介质 上 形成 的 磁化 轨迹 。 为 了 避免 干扰 ,磁道 和 磁道 
间 需 要 保持 一 定 的 距离 。 相 邻 两 条 磁道 中 心 线 之 间 的 距离 称 为 道 距 。 

(2) 位 密度 

位 密度 又 称 纵 回 密度 ,是 指 沿 磁 道 方 身上 单位 长 度 中 所 记录 的 二 进 制 信息 的 位 数 , 位 密 
度 的 单位 为 位 /in(bits per inch,bpi) 或 位 /mm(Cbits per millimeter,bpm)。 


2. 存储 容量 


存储 容量 是 指 整个 磁 介 质 存储 右 所 能 存储 的 二 进 制 信息 的 总 量 ,一 般 以 字 节 为 单位 表 
示 , 它 与 存储 介质 的 尺寸 和 记录 密度 直接 相关 。 

磁 介 质 存 储 融 的 存储 容量 有 非 格式 化 容量 和 格式 化 容量 两 种 指标 。 非 格式 化 容量 是 指 
磁 记 录 介 质 上 全 部 的 磁化 单元 数 ;格式 化 容量 是 指 用 户 实 际 可 以 使 用 的 存储 容量 ,也 就 是 制 
造 商 给 出 的 标 称 容量 。 格 式 化 容量 一 般 约 为 非 格式 化 容量 的 60% 一 70%。 


3. 平均 存 取 时 间 


在 磁 介 质 存储 器 中 , 当 磁 头 接 到 读 写 命令 后 ,从 原来 的 位 置 移动 到 指定 位 置 并 完成 读 写 
操作 的 时 间 称 为 存 取 时 间 。 对 于 采用 顺序 存 取 方式 的 多 道 并 行 读 写 的 磁带 存储 器 来 说 , 没 
有 寻找 磁道 的 问题 , 故 只 需 考 虑 磁头 等 待 记录 块 的 等 待 时 间 和 信息 的 读 写 操作 时 间 。 对 于 
采用 直接 存 取 方式 的 磁盘 存储 器 来 说 , 存 取 时 间 主 要 包括 4 个 部 分 :第 一 部 分 是 指 磁头 从 原 
先 位 置 移动 到 目的 磁道 所 需要 的 时 间 , 称 为 定位 时 间或 寻 道 时 间 ; 第 二 部 分 是 指 在 到 达 目 的 
磁道 以 后 ,等 待 被 访问 的 记录 块 旋 转 到 磁头 下 方 的 等 待 时 间 , 称 为 旋转 时 间或 等 待 时 间 ;第 
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三 部 分 是 信息 的 读 写 操作 时 间 , 也 称 为 传输 时 间 ; 最 后 是 磁盘 控制 器 的 开销 。 由 于 寻找 不 同 
磁道 和 等 待 不 同 记录 块 所 花 的 时 间 不 同 ,所 以 通常 取 它 们 的 平均 值 。 传 输 时 间 和 控制 器 的 
开销 相对 平均 寻 道 时 间 T. 和 平均 等 待 时 间 T。 来 说 要 小 得 多 ,所 以 磁盘 的 平均 存 取 时 间 了, 
约 等 于 


4. 数据 传输 率 


磁 介 质 存 储 需 在 单位 时 间 内 回 主 机 传送 数据 的 位 数 或 字 节 数 , 称 为 数据 传输 率 D,, 单 
位 为 b/s 或 B/s。 数 据 传输 率 ,正比 于 记录 密度 D 和 磁 记 录 介 质 通 过 磁头 时 的 速度 vw。 
DD= DX 
式 中 ; DD 一 一 记录 密度 。 对 于 单 道 存 取 的 装置 (如 磁盘 ) 为 位 密度 ;对 于 多 道 存 储 的 装置 (如 
磁带 ) 则 为 位 密度 与 磁道 数 之 乘积 。 
v 一 一 速度 。 对 磁 市 为 走 珊 速度 ;对 磁盘 为 记录 介质 通过 磁头 时 的 线 速度 。 


5. 误 码 率 


误 码 率 是 衡量 磁 介 质 存 储 融 出 错 概率 的 参数 , 它 等 于 谈 出 的 出 错 信息 位 数 和 读 出 总 的 
信息 位 数 之 比 。 

读 出 错误 有 便 错 误 和 软 错误 之 分 。 便 错误 又 称 不 可 恢复 的 错误 , 它 是 由 于 记录 介质 上 
存在 缺陷 等 原因 引起 的 ; 软 错误 又 称 可 恢复 的 错误 , 它 是 由 偶尔 落 入 记录 介质 和 读 写 磁头 之 
间 的 尘埃 或 电磁 干扰 引起 的 ,可 用 重复 的 读 操作 来 改正 。 


8.2.3 数字 磁 记 录 方 式 


为 了 提高 磁 介 质 人 存储 带 的 性 能 ,扩大 存储 容量 ,加 快 存 取 速 度 , 除 了 要 不 断 改善 磁头 和 
记录 介质 的 电磁 性 能 和 机 械 性 能 之 外 ,选用 高 性 能 的 数字 磁 记 录 方 式 对 提高 记录 密度 和 可 
徘 性 也 是 很 重要 的 。 

磁 记 录 方 式 按照 茶 种 规律 将 一 连 串 的 二 进 制 数字 信息 变换 成 记录 介质 上 相应 磁 通 翻转 
形式 。 磁 记录 方式 可 以 分 为 直接 记录 方式 和 按 位 编码 记录 方式 两 大 类 , 稼 见 几 种 记录 方式 
的 写 电 流 波 形 如 图 8-2 所 示 ,图 中 To 表示 位 周期 。 下 面 分 别 对 它们 进行 讨论 。 


1. 直接 记录 方式 


当 记 录 密 度 较 低 时 ,可 以 不 编码 ,直接 按 记录 信息 的 ”02 和 ”1 排序 记录 。 这 类 记录 方式 
有 以 下 3 种 。 

(1) 归 零 制 (RZ) 

记录 “12? 时 , 写 磁 头 线圈 中 通 以 正四 脉冲 电流 ;记录 ”02 时 , 通 以 反 向 脉冲 电流 。 巾 于 脉 
冲 电流 均 要 回 到 零 , 故 称 为 归 零 制 。 归 零 制 的 两 个 脉冲 之 间 有 一 段 间 隅 没有 电流 ,相应 的 这 
段 磁 层 未 被 磁化 。 

(2) 不 归 零 制 (NRZ) 

记录 “1” 时 , 写 磁头 线圈 中 通 以 正 同 电流 ;记录 “0” 时 , 通 以 反问 电流 。 由 于 磁头 中 电流 


EE 
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1 To 


8-2 ” 几 种 记录 方式 的 写 电流 波形 


不 回 到 零 , 故 称 为 不 归 零 制 。 如 果 记 录 的 相 邻 两 位 信息 相同 ( 即 连续 记录 "17 或 "0”) 时 , 写 电 
流 方向 不 变 ; 只 有 当 记 录 的 相 邻 两 位 信息 不 相同 ( 即 “0” 和 “1” 交 替 ) 时 , 写 电 流 才 改变 方 癌 ， 
所 以 又 称 为 异 码 变化 或 “ 见 变 就 翻 ? 的 不 归 堆 制 。 

(3) 不 归 零 -1 制 (NRZ-1) 

这 是 一 种 改进 的 不 归 零 制 , 记 录 “1? 时 ,在 位 周期 中 间 写 电流 改变 方向 ;而 记录 02? 时 , 写 
电流 方向 维持 不 变 , 所 以 称 为 见 "1? 就 翻 的 不 归 雪 制 。 


2. 按 位 编码 记录 方式 


下 面 几 种 记录 方式 都 属于 按 位 编码 记录 方式 。 

(1) 调 相 制 (PE) 

调 相 制 又 称 曼彻斯特 编码 , 它 采 用 0" 和 180" 相 位 的 不 同 分 别 表示 “1” 或 “0”。 它 的 编码 
规则 是 : 记录 “1” 时 , 写 电流 在 位 周期 中 间 由 负 变 正 ;记录 “0” 时 , 写 电 流 在 位 周期 中 间 由 正 
变 负 。 当 连续 出 现 两 个 或 两 个 以 上 “1” 或 “0” 时 ,为 了 维持 上 述 原 则 ,在 位 周期 的 边界 上 也 要 
翻转 一 次 。 这 种 记录 方式 常用 于 磁带 机 中 。 

(2) 调频 制 (FM) 

调频 制 是 根据 写 电 流 的 频率 来 区 分 记录 “1” 或 “0” 的 。 记 录 “1” 时 , 写 电 流 在 位 周期 
中 间 和 边界 各 改变 一 次 方 问 ;记录 02 时 , 写 电 流 仅 在 位 周期 边界 改变 一 次 方向 。 因 此 ， 
记录 “1” 的 磁 通 翻转 频率 为 记录 “0” 时 的 两 倍 , 故 又 称 售 频 制 。 夺 以 T, 表 示 位 周期 , 则 调 
频 制 的 磁 通 翻转 间距 为 0.5T。 和 T,。。 这 种 记录 方式 主要 应 用 于 早期 的 硬 磁 盘 机 和 单 密 
度 软磁盘 机 中 。 

(3) 改进 的 调频 制 (MFM) 

MFM 制 是 在 FM 制 基 础 上 改进 的 一 种 记录 方式 ,又 称 为 延 开 调制 码 或 密 勒 码 。 其 编 
码 规则 是 : 记录 “1” 时 , 写 电 流 在 位 周期 中 间 改 变 方向 ;记录 单独 的 一 个 “0” 时 , 写 电 流 不 改 
变 方向 ;记录 连续 的 两 个 “0” 时 , 写 电 流 在 位 周期 边界 改变 方 癌 。 
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改进 的 调频 制 的 磁 通 翻转 间距 有 3 种 : T,、1. 5T。、2T ,对 应 于 3 种 不 同 的 频率 ,所 以 8 
又 称 为 三 频 制 。MFM 制 的 磁 通 翻转 密度 低 于 FM 制 , MFM 制 的 最 小 磁 通 翻转 间距 Ti, 二 意 
To， 而 FM 制 的 Tw 二 0.5T ,也 就 是 MFM 制 可 以 减少 FM 制 的 磁 通 翻转 数目 ,使 之 在 相 
同 数量 的 磁 通 翻转 上 存储 两 倍 的 数据 。 因 此 ,采用 MFM 制 的 记录 密度 是 FM 制 的 两 倍 ,这 237 
种 记录 方式 主要 应 用 于 倍 密度 软磁盘 机 上 。 

(4) 改进 的 改进 型 调频 制 (M FM) 

M? FM 制 是 改进 的 MFM 制 方式 。 其 编码 规则 是 : 记录 “1” 时 , 写 电流 在 位 周期 中 间 改 
变 方向 ;记录 单独 的 一 个 “0? 时 , 写 电流 不 改变 方向 ;记录 连续 的 两 个 "0 时 , 写 电 流 在 第 二 个 
“0? 起 始 的 位 周期 边界 处 改变 方向 ;记录 连续 多 个 “0? 时 , 写 电 流 在 前 两 个 “0 的 位 周期 边界 
处 改变 方 回 ;以 后 每 隔 两 个 "0”( 假 设 其 紧 跟 着 的 下 一 位 还 是 ”02) ,在 位 周期 边界 处 写 电 流 再 
改变 一 次 方向 。 

改进 的 改进 型 调频 制 的 磁 通 翻转 间距 有 4 种 : Tu、 1.5Tu、 2Tu、2.5T ,对 应 于 4 种 不 同 
的 频率 ,所 以 又 称 为 四 频 制 。M2:FM 曾 在 软盘 机 和 一 些 特 殊 用 途 的 数字 磁带 机 中 使 用 。 


3. 成 组 编码 记录 方式 


除去 上 述 7 种 记录 方式 外 ,还 有 一 些 成 组 编码 方式 ,如 群 码 制 (GCR), 三 位 调制 码 
(C3PM) 和 游程 长 度 受 限 码 (RLL) 等 。 它 们 是 将 数据 序列 中 的 数据 位 几 位 分 成 一 组 ,然后 按 
一 定 的 变换 规则 变换 成 对 应 的 记录 码 , 再 采用 NRZ-1 制 写 人 记录 介质 ,从 而 使 记录 密度 得 
以 提高 。 

现今 硬盘 中 最 流行 的 编码 方式 为 游程 长 度 受 限 C(RLL) 码 , 它 的 记录 密度 是 调频 制 的 3 
倍 。 游 程 长 度 受 限 码 通常 每 次 编码 一 组 数据 而 不 是 单个 数据 。 游 程 长 度 受 限 源 于 这 些 编码 
的 两 个 主要 特性 , 即 两 个 实际 的 磁 通 转换 之 间 允 许 的 最 小 转换 单元 数目 (游程 长 度 ) 和 最 大 
的 转换 单元 数目 (游程 受 限 ) 。 该 方式 的 不 同 变种 使 用 不 同 的 长 度 和 受 限 参数 ,但 只 有 两 种 
真正 得 到 普及 : RLL2,7 和 RLL1,7。 表 8-1 列 出 了 RLL2,7 的 编码 规则 , 它 的 编码 严格 按 
照 2 一 4、 3 一 6、 4 一 8 的 规则 进行 变换 。 从 表 中 可 以 看 出 两 次 实际 的 磁 通 转换 工 之 间 最 小 转 
换 单 元 数目 CN 的 个 数 ) 是 2, 最 大 转换 单元 数目 是 7, 所 以 称 为 RLL2,7 码 。 


表 8-1 RLL2,7 数据 到 磁 通 转换 的 编码 


10 NTNN 011 NNTNNN 

11 TNNN 0010 NNTNNTNN 
000 NNNTNN 0011 NNNNTNNN 
010 TNNTNN 


注 : T= 二 磁 通 翻转 ,N= 二 无 磁 通 翻转 。 


如 果 最 后 一 组 的 数据 序列 无 法 在 表 8-1 中 找到 ,可 以 通过 添加 多 余 的 数据 位 以 填补 最 
后 一 组 序列 。 

调频 制 与 改进 的 调频 制 编码 也 可 看 作 是 游程 长 度 受 限 编码 的 一 种 。 调 频 制 称 为 
RLL0,1, 因 为 它 用 最 少 0 个 .最 多 1 个 转换 单元 区 分 两 个 磁 通 转换 ;改进 的 调频 制 称 为 
RLL1,3, 因 为 它 用 最 少 1 个 .最 多 3 个 转换 单元 区 分 两 个 磁 通 转换 。 


计算 机 组 成 原理 (第 4 版 ) 


8.2.4 编码 方式 的 比较 


尽管 存在 着 很 多 种 编码 方式 ,但 其 中 只 有 少 部 分 仍然 流行 。 近 年 最 流行 的 3 种 基本 编 
ESea 码 方 式 是 : 

JW 调频 制 (FM)。 

区 改进 的 调频 制 (MFM) 。 

(3 游程 长 度 受 限 (RLL) 。 

图 8-3 为 用 这 3 种 不 同 的 编码 方式 存储 ASCII 码 字 符 “X” 到 硬盘 上 的 写 电流 波形 。 


FM(RLL0,1) 编 码 (1X 时 钟 ) 


TNTITTITTITNTITIT T T IN IN TN 
MFM(RLL1,3) 编 码 (2X 时 钟 ) 
| | 0 I 


TNNTNNNTNTNNTNITIN 


RLL(RLL2,7) 编 码 (3X 时 钟 ) 
Devil UU 


TNNTNNTNNNNNNTNN 
T= 翻转 ( 磁 通 转 同 ) 

N= 无 翻转 

. = 数据 位 边界 (时 钟 定时 ) 


8-3 用 FM、MFM 和 RLL2,7 编码 ASCII 字符 “X” 的 写 电 流 波形 


在 每 种 编码 方式 采样 中 ,最 上 面 表示 各 个 位 周期 中 所 承 纳 的 单个 数据 位 01011000( 字 
符 “X” 的 ASCII 码 ) ,位 周期 由 时 钟 信号 及 时 分 开 , 如 图 表示 为 “.”; 中 间 是 实际 的 写 电流 波 
形 ; 最 下 面 表 示 磁 通 转 换 的 情况 ,用 全 代表 磁 通 翻转 ,用 N 代表 无 翻转 。 

FM 制 很 容易 解释 。 每 个 位 周期 有 两 个 转换 单元 : 一 个 代表 时 钟 信息 , 男 一 个 代表 数 
据 本 身 。 所 有 的 时 钟 转换 单元 都 包含 磁 通 翻转 ,而 只 有 数据 位 为 "1? 时 数据 转换 单元 才 包 含 
磁 通 翻转 ,数据 位 为 "0 时 无 磁 通 翻 转 。 

MFM 制 的 每 个 数据 位 也 含有 时 钟 和 数据 单元 。 但 是 ,只 有 当 一 个 “0” 紧 跟着 另 一 个 
“0” 存 储 时 ,时钟 转换 单元 才 含 有 一 个 磁 通 翻转 。 从 左边 开始 ,第 一 位 为 0, 而 前 面 的 位 未 知 
(假设 为 0) ,因此 磁 通 转换 模式 为 TN; 下 一 位 为 1, 通 常 编码 为 转换 模式 NT; 下 一 位 为 0, 由 
于 前 面 为 1, 因而 存 为 NN。 

RLL2,7 由 于 是 对 成 组 的 数据 位 编码 而 不 是 对 单独 的 位 编码 ,因而 看 起 来 比较 复杂 。 
从 左边 开始 ,第 一 组 与 表 8-1 中 列 出 的 组 相 匹 配 的 是 第 一 个 3 位 数 : 010, 这 3 位 转换 为 磁 通 
转换 模式 TNNTNN; 下 两 位 11 可 转换 为 TNNN ,最 后 一 组 000 可 转换 为 NNNTNN 结束 。 
本 例 中 无 须 添加 多 余 的 位 填充 最 后 一 组 。 在 本 例 中 ,任何 两 个 磁 通 翻转 工 之 间 N 的 最 小 数 
目 与 最 大 数目 为 2 和 6, 但 在 其 他 例子 中 最 大 转换 单元 数目 可 以 达到 7, 这 就 是 RLL2,7 命 
名 的 由 来 。 由 于 它 记 录 的 磁 通 翻转 数目 比 MFM 更 少 ,因而 时 钟 频率 可 增 至 FM 的 3 倍 ， 
MFM 的 1.5 倍 ,使 得 在 相同 的 空间 内 存储 更 多 的 信息 。 
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8.3” 磁 介质 存储 设备 


磁 介 质 存 储 表 主要 包括 硬盘 存储 如 、 软 盘存 备 此 和 磁 市 人 存 备 此 。 重 盘存 储 天 的 记录 载 
体 是 硬 质 材料 的 , 它 的 容量 大 、 位 价格 低 , 是 当今 辅助 存储 事 的 主体 。 软 盘存 储 问 和 磁带 存 
储 天 的 记录 载体 是 软 质 材料 的 ,软盘 存储 天 在 20 世纪 90 年 代 还 是 微机 辅助 存储 需 的 标准 
配置 ,但 它 的 容量 小 单位 容量 成 本 高 ,速度 慢 且 可 徘 性 差 , 随 看 计算 机 技术 的 发 展 , 冒 经 应 
用 最 广泛 的 软盘 现在 已 基本 淡出 人 们 的 视线 。 


8.3.1 硬盘 存储 器 的 基本 结构 与 分 类 


人 硬盘 存储 硕 具 有 存储 容量 大 ,使 用 寿命 长 , 存 取 速度 较 快 的 特点 。 便 盘存 储 颖 的 人 硬件 包 
括 便 盘 控制 硕 ( 适 配 需 )、 便 盘 驱 动 顺 以 及 连接 电费。 硬盘 控制 需 (CHDC) 对 便 盘 进行 管理 ， 
并 在 主机 和 硬盘 之 间 传 送 数 据 ; 硬 盘 驱 动 器 (HDD) 中 有 盘 片 .磁头 、 主 轴 电 机 ( 盘 片 旋转 驱 
动机 构 ) 磁头 定位 机 构 . 谈 写 电 路 和 控制 逻辑 等 。 新 型 的 便 盘 都 已 将 控制 硕 集 成 到 驱动 需 
单元 中 了 。 

为 了 提高 单 台 驱动 右 的 存储 容量 ,在 硬盘 驱动 器 内 使 用 了 多 个 盘 片 ,它们 被 秋装 在 主轴 
上 ,构成 一 个 盘 组 ;每 个 盘 片 的 两 面 都 可 用 作 记 录 面 ,所 以 一 个 硬盘 的 存储 容量 又 称 为 盘 组 
容量 。 

根据 头 - 盘 是 否 是 一 个 密封 的 整体 ,硬盘 存储 硕 可 分 为 温 彻 斯 特 盘 和 非 温 彻 斯 特 盘 两 
类 。 温 彻 斯 特 盘 的 主要 特点 是 磁头 、 盘 片 、 磁 头 定 位 机 构 .主轴 ,甚至 连 读 写 驱动 电路 等 都 被 
密封 在 一 个 盘 盒 内 ,构成 一 个 涉 - 盘 组 合体 。 这 个 组 合体 不 可 随意 拆 印 , 它 的 防 尘 性 能 好 ,可 
靠 性 高 ,对 使 用 环境 要 求 不 高 。 而 非 温 彻 斯 特 式 磁盘 的 磁头 和 盘 片 等 不 是 密封 的 ,因此 要 求 
有 超 净 的 使 用 环境 。 

根据 磁头 是 否 可 移动 , 便 盘 存储 名 可 分 为 固定 头 硬 盘 和 活动 头 便 盘 两 类 。 固 定 头 人 硬盘 
机 中 ,每 个 磁道 对 应 一 个 磁头 。 工 作 时 ,磁头 无 径 向 移动 ,其 特点 是 存 取 速 度 快 ,省 去 了 磁头 
找 磁道 的 时 间 ,磁头 处 于 加 载 工 作 状 态 即 可 开始 读 写 。 但 是 ,由 于 磁头 太 多 ,使 磁盘 的 道 密 
度 不 可 能 很 高 ,而 整个 磁盘 机 的 造价 却 比 较 高 。 活 动 头 硬 盘 机 中 ,每 个 盘面 上 只 有 一 个 读 写 
头 ,安装 在 读 写 臂 上 , 当 需 要 在 不 同 磁道 上 读 写 时 ,要 驱动 读 写 臂 沿 盘 面 作 径 向 移动 。 由 于 
增加 了 寻 道 时 间 , 所 以 其 存 取 时 间 比 固定 头 人 硬盘 机 要 长 。 


8.3.2 硬盘 驱动 器 
目前 第 用 的 人 硬盘 驱动 右 都 是 活动 头 的 温 彻 斯 特 盘 , 何 称 温 盘 。 
1. 磁头 


温 盘 的 磁头 采用 接触 局 停 式 。 所 谓 接触 司 停 , 是 指 在 该 写 操 作 时 磁头 浮 空 ,不 与 盘面 记 
录 区 相 接触 ,以 免 划 伤 记录 区 。 但 是 ,由 于 磁头 的 浮 起 要 依 重 盘 片 高速 旋 转 时 产生 的 气垫 浮 
力 , 因 此 在 局 动 前 和 停止 后 ,磁头 将 仍 与 盘面 接触 。 具 体 的 做 法 是 : 在 盘面 记录 区 与 轴 心 之 
间 有 一 段 空 日 区 ,被 当 作 启 停 区 或 者 陆 区 。 未 局 动 前 及 停止 后 ,磁头 停 在 局 停 区 ,与 盘面 接 
触 。 当 盘 片 旋转 并 达到 额定 转速 时 ,气垫 浮力 使 磁头 浮 起 并 达到 所 需 的 浮动 高 度 ,然后 将 磁 
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头 向 外 移 至 0 号 磁道 ,准备 寻 道 。 当 读 写 工作 完毕 后 ,必须 先 将 磁头 移 至 启 停 区 , 盘 片 减速 
至 静止 ,相应 地 磁头 着 陆 ,然后 才能 关机 。 

在 读 写 时 ,磁头 与 盘面 之 间 的 间隙 (又 称 飞 高 ) 极 小 , 仅 有 0. 2 一 0. 5pm, 甚 至 0. 08jm。 
这 样 ,磁头 在 通 以 写 电流 后 ,盘面 的 磁化 单元 很 小 ,记录 密度 可 以 大 大 提高 。 


2. 磁头 定位 系统 


磁头 定位 系统 驱动 磁头 泊 盘 面 径 四 移动 寻 近 并 精确 定位 。 磁 头 定 位 系统 应 包括 以 下 
操作 : 

J 硬盘 驱动 硕 局 动 后 ,或 是 中 途 寻 道 出 错 后 ,要 使 磁头 准确 地 回 到 0 号 磁道 ,以 等 竺 寻 
道 命令 。 

@ 要 能 快速 \ 准 确 地 将 磁头 移 到 指定 磁道 的 中 心 位 置 。 

G) 当 人 硬盘 驱动 带 发 生 故 障 或 掉 电 后 ,要 使 磁头 迅速 退出 盘面 数据 区 ,以 保护 盘面 免 受 

为 了 获得 较 高 的 站 密度 ,定位 系统 必须 非常 精密 ;为 了 提高 磁盘 的 寻 记 速度 ,定位 系统 
的 速度 应 尽量 快 。 目 前 ,在 磁盘 中 采用 的 磁头 定位 系统 有 下 述 两 种 类 型 。 

(1) 步 进 电机 定位 机 构 

在 近 密 度 不 是 很 高 的 小 容量 磁盘 中 ,一般 采 用 步 进 电机 驱动 。 整 个 定位 机 构 是 一 个 开 
环 系统 。 根 据 现行 磁道 号 与 目的 磁 站 号 之 差 , 求 得 步 进 脉冲 数 。 每 发 一 个 步 进 脉冲 ,脉冲 移 
动 一 个 道中 。 步 进 电机 定位 机 构 的 结构 紧凑 .控制 简单 ,但 定位 精度 比较 低 。 

(2) 音 圈 电 机 定位 机 构 

在 道 密 度 较 高 的 磁盘 中 ,多 采用 音 圈 电机 驱动 。 音 圈 电 机 是 线性 电机 ,可 以 直接 驱动 磁 
头 作 直 线 运 动 ,整个 定位 系统 是 一 个 市 有 速度 和 位 置 反 馈 的 闭环 调 市 日 动 控 制 系统 ,其 特 操 
是 寻 道 速度 快 ,定位 精度 高 。 


8.3.3 硬盘 的 信息 分 布 和 磁盘 地 址 
1. 硬盘 的 信息 分 布 
在 硬盘 中 信息 分 布 呈 以 下 层次 : 记录 面 .圆柱 面 . 磁 道 和 扁 区 ,如 图 8-4 所 示 。 


8-4 磁盘 信息 分 布 示意 图 


外 部 设备 


(1) 记录 面 

一 台 便 盘 驱 动 器 中 有 多 个 盘 片 ,每 个 盘 片 有 两 个 记录 面 ,每 个 记录 面 对 应 一 个 人 磁头 ,所 
以 记录 面 号 就 是 磁头 号 ,如 图 8-4(a) 所 示 。 所 有 的 磁头 安装 在 一 个 公用 的 传动 设备 或 文 架 
上 ,磁头 一 致 地 治 盘 面 径 回 移 动 , 单 个 磁头 不 能 单独 地 移动 。 

(2) 磁道 

在 记录 面 上 ,一 条 条 磁道 形成 一 组 同心 圆 , 最 外 圈 的 磁道 为 0 号 , 往 内 则 磁道 号 逐步 增 
加 ,如 图 8-4(b) 所 示 。 

(3) 圆柱 面 

在 一 个 盘 组 中 ,各 记录 面 上 相同 编号 (位 置 ) 的 诸 磁 道 构 成 一 个 圆柱 面 , 如 图 8-4(c) 所 
示 。 例 如 , 某 驱 动 咒 有 4 片 8 面 , 则 8 个 0 号 磁道 构成 0 号 圆柱 面 ,8 个 1 号 磁道 构成 1 号 圆 
柱 面 …… 人 硬盘 的 圆柱 面 数 就 等 于 一 个 记录 面 上 的 磁道 数 , 圆 柱 面 号 即 对 应 的 磁道 号 。 

引入 圆柱 面 的 概念 是 为 了 提高 硬盘 的 存储 速度 。 当 主机 要 存 人 一 个 较 长 的 文件 时 ,者 
一 条 磁道 存 不 完 ,就 需要 存放 在 几 条 磁道 上 。 这 时 应 选择 位 于 同一 记录 面 上 的 几 条 磁道 ? 
还 是 选择 同一 圆柱 面 上 的 几 条 磁道 呢 ? 很 明显 ,如 果 选 择 同 一 记录 面 上 的 不 同 磁 道 , 则 每 次 
换 道 时 都 要 进行 磁头 定位 操作 ,速度 较 慢 。 如 果 选 择 同 一 圆柱 面 上 的 不 同 磁道 , 则 由 于 各 记 
录 面 的 磁头 已 同时 定位 , 换 道 的 时 间 只 是 磁头 选择 电路 的 译 码 时 间 ,相对 于 定位 操作 可 以 忽 
略 不 计 , 所 以 在 存 人 文件 时 ,应 首先 将 一 个 文件 尽 可 能 地 存放 在 同一 圆柱 面 中 。 如 果 仍 存放 
不 完 , 再 存 人 相 邻 的 圆柱 面 内 。 

(4) 局 区 

通常 将 一 条 磁道 划分 为 大 干 个 段 , 每 个 段 称 为 一 个 悄 区 或 甩 段 ,每 个 而 区 存放 一 个 定 长 
信息 块 (如 512 个 字 节 ) ,如 图 8-4(b) 所 示 。 一 条 磁道 划分 多 少 月 区 ,每 个 而 区 可 存放 多 少 
个 字 节 ,一 般 由 操作 系统 决定 。 磁 道上 的 衣 区 编号 从 1 开始 ,不 像 磁 头 或 柱 面 编号 从 
0 开始 。 


2. 磁盘 地 址 


主机 向 磁盘 控制 器 送出 有 关 寻 址 信息 ,磁盘 地 址 一 般 表示 为 : 驱动 需 号 .圆柱 面 (磁道 ) 
号 、 记 录 面 (磁头 ) 号 、 户 区 号 。 

通常 ,主机 通过 一 个 硬盘 控制 器 可 以 连接 几 台 硬盘 驱动 器 ,所 以 需 送 出 驱动 器 号 。 调 用 
磁盘 篆 以 文件 为 单位 , 故 寻 址 信息 一 般 应 当 给 出 文件 起 始 位 置 所 在 的 圆柱 面 号 与 记录 面 号 
(这 就 确定 了 具体 磁道 ) 、 起 始 届 区 号 ,并 给 出 有 而 区 数 ( 交 换 量 )。 


8.3.4 硬盘 存储 器 的 技术 参数 
1. 硬盘 的 主要 性 能 指标 


(1) 人 硬盘 容量 

便 盘 容量 当然 是 越 大 越 好 。 目 前 ,微型 计算 机 中 的 人 硬盘 容量 已 经 从 数 百 吉 字 节 发 展 到 
数 千 言 字 节 ( 即 数 个 太 字 节 ) ,更 大 容量 的 便 盘 还 将 不 断 推 出 。 

硬盘 的 容量 指标 还 包括 硬盘 的 单 碟 容量 。 所 谓 单 矶 容量 ,是 指 硬盘 单 片 盘 片 的 容量 。 
单 碟 容 量 越 大 ,单位 成 本 越 低 , 平 均 访 问 时 间 也 越 短 。 目 前 ,硬盘 的 单 碟 容量 在 320GB 至 
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1TB 不 等 。 

(2) 硬盘 转速 

鲁 盘 主轴 电机 的 旋转 速度 是 决定 便 盘 内 部 传输 率 的 关键 因素 之 一 ,在 很 大 程度 上 直接 
影响 到 硬盘 的 速度 。 硬 盘 转 速 以 每 分 钟 多 少 转 (RPM) 来 表示 ,RPM 值 越 大 ,内 部 传输 率 就 
越 快 ,访问 时 间 就 越 短 ,人 硬盘 的 整体 性 能 也 就 越 好 。 最 初 , 便 盘 的 主轴 电机 转速 一 般 为 
3600RPM ,现在 硬盘 的 转速 为 5400RPM 或 7200RPM ,高 转速 硬盘 则 可 达到 10 000RPM 甚 
至 15 000RPM。 高 转速 可 缩短 便 盘 的 平均 寻 道 时 间 和 实际 读 写 时 间 , 但 随 着 硬盘 转速 的 不 
断 提高 也 带 来 了 温度 升 高 .电机 主轴 磨损 加 大 工作 噪音 增 大 等 负面 影响 。 

(3) 道 密度 

因为 盘 片 组 是 密封 的 .不 可 更 换 的 ,硬盘 上 的 磁道 密度 可 以 非常 高 。 今 天 的 硬盘 驱动 器 
在 介质 上 的 道 密度 可 达 38 000TPI 或 更 高 。 

(4) 平均 存 取 时 间 

平均 存 取 时 间 又 称 平均 访问 时 间 ,如 果 忽 略 信息 的 传输 时 间 和 磁盘 控制 硕 的 开销 , 则 它 
是 指 磁 头 从 起 始 位 置 到 到 达 目 标 磁道 位 置 ,并 且 从 目标 磁道 上 找到 要 读 写 的 数据 扇 区 所 需 
要 的 时 间 , 包 括 了 人 硬盘 的 寻 道 时 间 和 等 待 时 间 , 它 体 现 了 硬盘 的 读 写 速度 。 

硬盘 的 平均 寻 道 时 间 是 指 硬盘 的 磁头 移动 到 盘面 指定 磁道 所 需要 的 时 间 。 这 个 时 间 当 
然 越 小 越 好 ,硬盘 的 平均 寻 道 时 间 通 常 在 8 一 12ms, 而 SCSI 硬盘 则 应 小 于 或 等 于 8ms。 

硬盘 的 等 待 时 间 又 称 潜伏 期 ,是 指 磁头 已 处 于 要 访问 的 磁道 ,等 待 所 要 访问 的 扇 区 旋转 
至 磁头 下 方 的 时 间 。 平 均等 待 时 间 为 盘 片 旋 转 一 周 所 需要 的 时 间 的 一 半 , 一 般 在 4ms 
以 下 。 

(5) 缓存 

缓存 是 硬盘 控制 希 上 的 一 块 内 存 芯 片 , 具 有 极 快 的 存 取 速度 , 它 是 硬盘 内 部 存储 和 外 界 
接口 之 间 的 缓冲 需 。 由 于 人 硬盘 的 内 部 数据 传输 率 和 外 部 数据 传输 率 不 同 , 组 存在 其 中 起 到 
一 个 缓冲 的 人 作用。 缓存 的 大 小 与 速度 是 直接 关系 到 人 硬盘 的 传输 速度 的 重要 因素 。 当 硬盘 存 
取 和 零碎 数据 时 ,需要 不 断 地 在 硬盘 与 内 存 之 间 交 换 数 据 , 如 果 缓 存 足够 大 , 则 可 以 将 那些 零 
碎 数 据 暂 存在 缓存 中 , 既 减 小 了 外 系统 的 负荷 ,也 提高 了 数据 的 传输 速度 。 

早期 的 硬盘 缓存 基本 都 很 小 ,只 有 几 百 千 字 节 , 而 8 一 128MB 已 是 现今 主流 硬盘 的 缓存 
设计 ,在 服务 器 或 特殊 应 用 领域 中 还 有 缓存 容 量 更 大 的 产品 甚至 达到 了 256MB。 

(6) 数据 传输 率 

硬盘 的 数据 传输 率 分 为 内 部 数据 传输 率 和 外 部 数据 传输 率 。 内 部 数据 传输 率 也 称 为 持 
续 传 输 率 , 指 的 是 磁头 与 便 盘 缓存 之 间 的 数据 传输 率 , 它 主要 依赖 于 硬盘 的 旋转 转速 。 外 部 
数据 传输 率 也 称 为 突 发 数据 传输 率 , 指 的 是 系统 总 线 与 硬盘 缓存 之 间 的 数据 传输 率 ,外 部 数 
据 传输 率 与 硬盘 接口 类 型 和 缓存 大 小 有 关 。 


2. 硬盘 的 接口 标准 


硬盘 接口 是 硬盘 与 主机 系统 间 的 连接 部 件 , 不 同 的 硬盘 接口 决定 着 硬盘 与 计算 机 之 间 
的 连接 速度 ,在 整个 系统 中 ,硬盘 接口 的 优 劣 直接 影响 着 程序 运行 速度 的 快慢 和 系统 性 能 的 
好 坏 。 从 整体 的 角度 上 ,硬盘 接口 分 为 IDE、.SATA、SCSI 和 SAS 等 。 

IDE 接口 也 称 ATA ,或 称 并 行 ATA(PATA), 采 用 16 位 数据 并 行 传送 方式 。IDE 接 
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口 曾 经 具有 相当 辉煌 的 历史 ,从 ATA/33 发 展 到 ATA/100、ATA/133 等 (ATA/133 代表 
外 部 数据 传输 率 的 理论 最 大 值 是 133MB/s) 。 然 而 , 随 着 SATA 接口 的 诞生 ,IDE 接口 的 硬 
盘 已 基本 淡出 了 人 们 的 视线 。 

SATA 是 Serial ATA 的 缩写 , 即 串 行 ATA, 这 是 一 种 完全 不 同 于 传统 并 行 ATA 的 新 
型 硬盘 接口 类 型 。 与 并 行 ATA 相 比 ,SATA 具有 比较 大 的 优势 。 首 先 ,SATA 以 连续 串 行 
的 方式 传送 数据 ,可 以 使 用 较 高 的 工作 频率 来 提高 数据 传输 的 带宽 。SATA 一 次 传送 1 位 
数据 ,能 减少 SATA 接口 的 针脚 数目 。 其 次 ,SATA 的 起 点 更 高 、 发 展 潜 力 更 大 ,SATA1.0 
的 数据 传输 率 可 达 150MB/s, 这 比 最 快 的 并 行 ATA( 即 ATA/133) 所 能 达到 的 133MB/s 最 
高 数据 传输 率 还 高 ,SATA 2.0 的 数据 传输 率 已 经 高 达 300MB/s, 而 SATA 3.0 的 数据 传 
输 率 则 更 可 高 达 600MB/s。SATA 接口 具备 很 强 的 纠 错 能 力 ,还 具有 结构 简单 、 支 持 热 插 
拔 的 优点 。 几 种 磁盘 接口 的 比较 见 表 8-2。 


表 8-2 几 种 磁盘 接口 的 比较 


SATA 2.0 00 5 
SATA1.0 50 


PATA 1. 33 133 0. 5 


在 不 同 版 本 的 SATA 接口 中 ,描述 速率 的 单位 有 所 不 同 , 如 SATA 1.0 沿 用 了 PATA 
的 方法 ,单位 为 “MB/s”,SATA 2.0 之 后 单位 为 “Gb/s”, 由 于 采用 8bit/10bit 编码 ,所 以 可 
以 认为 300MB/s 就 等 于 3Gb/s。 

SCSI 是 小 型 计算 机 系统 接口 的 缩写 , 它 并 不 是 专门 为 硬盘 设计 的 接口 ,而 是 一 种 接 入 
各 种 类 型 设备 的 通用 快速 接口 。SCSI 接口 具有 应 用 范围 广 、 多 任务 、 市 宽大 以 及 热 插 拔 等 
优点 ,但 价格 较 高 ,主要 应 用 于 中 、 高 端 服务 器 和 高 档 工 作 站 中 。Ultra160 SCSI 的 数据 传输 
率 为 160MB/s,Ultra320 SCSI 的 数据 传输 率 为 320MB/s。 

SAS(Serial Attached SCSID 即 串 行 连接 SCSI, 是 新 一 代 的 SCSI 技术 ,和 现在 流行 的 
Serial ATA(CSATA) 便 盘 相 同 ,都 是 采用 串 行 技术 以 获得 更 高 的 传输 速度 ,并 通过 缩短 连 线 
改善 内 部 空间 。SAS 是 并 行 SCSI 接口 之 后 开发 出 的 全 新 接口 。 此 接口 的 设计 是 为 了 改善 
存储 系统 的 效能 .可 用 性 和 扩充 性 ,并 且 提 供与 SATA 硬盘 的 兼容 性 。 和 传统 并 行 SCSI 接 
口 比较 起 来 , SAS 不 仅 在 接口 速度 上 得 到 显著 提升 ,传输 速率 高 达 300MB/s, 未 来 会 达到 
600MB/s 甚至 更 高 ,而 且 由 于 采用 了 串 行 线 缆 ,可 以 实现 更 长 的 连接 距离 ,还 能 够 提高 抗 干 
扰 能 力 。 


3. 硬盘 参数 的 计算 


下 面 举例 说 明 硬 盘存 储 器 参数 的 计算 方法 。 设 有 一 个 盘面 直径 为 18 英寸 (in) 的 磁盘 
组 ,有 20 个 记录 面 ,每 面 有 5 英寸 的 区 域 用 于 记录 信息 ,记录 密度 为 100 道 / 英 寸 CTPI) 和 
1000b/ 英 寸 (bpi) ,转速 为 2400r/min, 道 间 移 动 时 间 为 0.2ms, 试 计算 该 盘 组 的 容量 .数据 传 
输 率 和 平均 存 取 时 间 。 
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每 一 记录 面 的 磁道 数 N 为 : 

N=5 英 寸 / 面 X100 道 / 英 寸 二 500 道 / 面 
最 内 圈 磁 道 的 周 长 为 : 

L= 二 xX(18 一 2X5) 英 寸 =25. 12 英寸 
以 最 内 圈 磁 道 的 周 长 当 作 每 条 磁道 的 长 度 , 故 该 盘 组 的 存储 容量 ( 非 格 式 化 容量 ) 为 : 
C 一 1000b/ 英 寸 X25. 12 英寸 / 道 X500 道 / 面 X20 面 =251.2X10'b==31.4X10°B 
磁盘 旋转 一 圈 的 时 间 为 : 


= 100r 7 X60s/min= 0. 025Ss 一 25ms 


数据 传输 率 为 : 


-着 一 25 
一 0.1256X105 B/s<z*0. 12MB/s 
平均 存 取 时 间 为 : 


TX [二 2 |ms~6oms 


从 上 面 的 计算 中 可 得 到 : 
韭 格式 化 容量 二 最 大 位 密度 X 最 内 圈 磁 道 周 长 X 总 磁道 数 
新 的 磁盘 在 使 用 之 前 必须 先进 行 格式 化 。 格 式 化 实际 上 就 是 在 磁盘 上 划分 记录 区 , 写 
入 各 种 标志 信息 和 地 址 信息 。 这 些 信 息 占 用 了 磁盘 的 存储 空间 , 故 格式 化 之 后 的 有 效 存 储 
容量 要 小 于 非 格式 化 容量 。 它 的 计算 公式 为 : 
格式 化 容量 = 每 道 甩 区 数 X 户 区 容量 X 总 人 磁道 数 


8.3.5 硬盘 的 分 区 域 记 录 


传统 鲁 盘 驱动 右 的 每 个 磁道 上 记录 的 慎 区 数 是 相同 的 ,因而 存储 的 信息 量 也 是 相同 的 ， 
这 意味 看 在 磁盘 上 位 密度 是 变化 的 。 因 为 内 圈 磁 道 的 周 长 短 ,外 圈 磁 道 的 周 长 长 ,所 以 内 圈 
磁道 的 位 密度 高 ,外 圈 磁 道 的 位 密度 低 , 最 内 圈 磁 道 的 位 密度 (最 大 位 密度 ) 决 定 了 磁盘 驱动 
估 的 容量 。 又 因为 每 个 磁道 记录 的 信息 量 及 转速 是 相同 的 ,所 以 它们 的 数据 传输 率 也 是 相 
同 的 。 图 8-5 表示 每 个 磁道 有 相同 数量 刷 区 的 记录 。 

由 于 外 圈 磁 道 比 内 圈 磁 道 要 长 一 些 , 但 存储 的 信息 量 却 相同 ,所 以 外 圈 磁 道上 明显 地 存 
在 着 浪 费 。 采 用 分 区 域 记 录 (Zoned Recording) 技 术 可 以 增加 便 盘 驱动 带 的 容量 。 分 区 域 
记录 就 是 把 磁盘 柱 面 分 成 一 系列 的 组 ,又 称 区 域 (Zoned) 。 由 于 外 圈 磁 道 有 更 长 的 周 长 ,所 
以 外 层 磁 道 要 比 内 层 磁道 包含 更 多 的 扇 区 , 即 外 圈 磁 道上 保存 的 信息 比 内 圈 磁 道 多 。 
图 8-6 表示 了 采用 分 区 域 记录 驱动 硕 的 磁盘 朵 区 分 布 情况 。 

分 区 域 记 录 的 另 一 个 影响 是 数据 传输 率 随 磁头 所 处 的 区 域 而 变化 。 分 区 域 驱 动 硕 还 是 
以 恒定 速度 诈 转 ,可 是 由 于 外 层 区 域 每 磁道 有 更 多 的 朵 区 ,所 以 数据 传输 速度 要 更 快 一 些 。 
这 就 是 当今 驱动 硕 标 注 最 小 和 最 大 连续 传输 速率 的 原因 ,因为 传输 速率 取决 于 磁头 谈 写 的 
位 置 。 

分 区 域 记 录 技 术 的 使 用 ,大 大 地 提高 了 人 鲁 盘 利用 率 , 与 采用 每 磁道 固定 悄 区 的 人 硬盘 比 
较 , 使 驱动 需 增 加 了 20% 一 50 为 的 硬盘 容量 。 实 际 上 ,现在 所 有 的 硬盘 都 采用 分 区 域 记 录 。 
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图 8-5 每 个 磁道 有 相同 数量 扇 区 图 8-6 ”分 区 域 记 录 磁 盘 扇 区 分 布 


8.3.6 硬盘 的 NCQ 技术 


NCQ(Native Command Queuing ,全 速 命令 排队 ) 技 术 。 它 通过 对 内 部 队列 中 的 命令 进 
行 重 新 排序 实现 智能 数据 管理 ,避免 像 传 统 硬盘 那样 机 械 地 按照 接收 命令 的 先后 顺序 移动 
磁头 读 写 硬盘 的 不 同位 置 ,从 而 减少 了 磁头 反复 移动 珊 来 的 损耗 ,延长 了 硬盘 的 寿命 。 
NCQ 技术 是 SATA 2.0 规范 中 的 重要 组 成 部 分 。 

根据 磁盘 地 址 ,硬盘 寻 址 的 过 程 如 下 : 

。 寻找 目标 圆柱 面 。 

。 寻找 目标 盘面 。 

。 寻找 目标 扇 区 。 

大 多 数 情况 下 数据 存 人 硬盘 并 非 是 顺序 存 信 ,而 是 随机 存 人 ,甚至 有 可 能 一 个 文件 被 分 
配 在 不 同 盘 片上 。 对 于 不 支持 NCQ 技术 的 硬盘 来 说 ,大 量 的 数据 读 写 需要 反复 重复 上 面 
的 步骤 ,而 对 于 不 同位 置 的 数据 存 取 ,磁头 则 需要 更 多 的 操作 ,这 样 降低 了 存 取 效率 。 而 支 
持 NCQ 技术 的 人 硬盘 对 接收 到 的 命令 按照 它们 访问 的 地 址 的 距离 进行 了 重 排 列 , 对 人 硬盘 机 
械 动 作 的 执行 过 程 实施 乔 能 化 的 内 部 管理 ,减少 了 磁头 壁 来回 移动 的 时 间 。 

例如 , 回 硬盘 先后 下 达 了 一 组 数据 传送 命令 , 按 次 序 磁头 可 能 会 先 读 取 260 书 区 ,再 读 
取 7660 扇 区 ,然后 又 读 取 261 肩 区 …… 如 果 对 队列 中 的 命令 进行 优化 排列 ,可 以 先 读 
260 扇 区 ,接着 依次 读 261 扇 区 ,最 后 读 取 7660 扇 区 …… 显 然 , 命 令 重 排列 后 减少 了 磁头 臂 
来 回 移动 的 时 间 ,使 数据 读 取 更 有 效 。 有 效 的 排序 算法 除了 考虑 目标 数据 的 线性 位 置 , 也 会 
考虑 其 角度 位 置 , 并 且 还 要 对 线性 位 置 和 角度 位 置 进行 优化 ,以 使 总 线 的 服务 时 间 最 小 ,这 
个 过 程 也 称 作 “基于 寻 道 和 旋转 优化 的 命令 重新 排序 ”。 


8.4 磁盘 阵列 


磁盘 阵列 (RAID) 具 有 容量 大 、 速 度 快 .可 靠 性 高 .造价 低廉 的 特点 , 它 是 目前 解决 计算 
机 1/O 瓶颈 的 有 效 方法 之 一 ,有 着 广阔 的 发 展 前 景 。 
8.4.1 RAID 简介 


RAID 是 由 美国 加 州 大 学 伯克利 分 校 的 D. A. Patterson 教授 在 1988 年 提出 的 。RAID 
是 Redundant Array of Inexpensive Disks 的 缩写 ,直译 为 “廉价 元 余 磁 盘 阵 列 ”, 简 称 为 “ 磁 
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盘 阵 列 ”。 后 来 RAID 中 的 字母 工 被 改作 为 Independent, RAID 就 成 了 “独立 匈 余 磁盘 阵 
列 ”, 但 这 只 是 名 称 的 变化 ,实质 性 的 内 容 并 没有 改变 。 可 以 把 RAID 理解 成 一 种 使 用 磁盘 
驱动 器 的 方法 , 它 将 一 组 磁盘 驱动 器 用 某 种 逻辑 方式 联系 起 来 , 作 
为 逻辑 上 的 一 个 磁盘 驱动 器 来 使 用 ,图 8-7 为 磁盘 阵列 外 形 。 一 般 
情况 下 ,组 成 的 逻辑 磁盘 驱动 需 的 容量 要 小 于 各 个 磁盘 驱动 大 容量 
的 总 和 。RAID 的 具体 实现 可 以 靠 便 件 ,也 可 以 靠 软件 ,Windows 
NT 操作 系统 就 提供 软件 RAID 功能 。 

RAID 的 优点 如 下 : 

QD 成 本 低 , 功 耗 小 ,传输 速率 高 。 在 RAID 中 ,可 以 让 很 多 磁 
盘 驱 动 器 同时 传输 数据 ,而 这 些 磁盘 驱动 器 在 逻辑 上 又 是 一 个 磁盘 
驱动 器 ,所 以 使 用 RAID 可 以 达到 单个 磁盘 驱动 器 几 倍 、 几 十 倍 甚 
至 上 百倍 的 速率 ， 图 8-7 磁盘 阵列 外 形 

@ 提供 容错 功能 。 这 是 使 用 RAID 的 第 二 个 原因 ,如 果 不 考 
虑 磁盘 上 的 循环 元 余 校 验 (CRC) 码 ,普通 磁盘 驱动 器 无 法 提供 容错 功能 。RAID 的 容错 是 
建立 在 每 个 磁盘 驱动 需 的 硬件 容错 功能 之 上 的 ,所 以 它 提供 更 高 的 安全 性 。 

@) RAID 比 起 传统 的 大 直径 磁盘 驱动 器 来 ,在 同样 的 容量 下 ,价格 要 低 许 多 。 


8.4.2 RAID 的 分 级 


RAID 可 以 分 为 7 个 级 别 , 即 RAIDO 一 RAID6 ,如 表 8-3 所 示 。 在 RAID1 ~ RAID6 
的 几 种 方案 中 ,不 论 何 时 有 磁盘 损坏 ,都 可 以 随时 拔 出 损坏 的 磁盘 后 再 插入 好 的 磁盘 
(需要 人 硬件 上 的 热 搬 拔 文 持 ) ,数据 不 会 受 损 , 失 效 盘 的 内 容 就 可 以 很 快 地 重建 ,重建 的 
工作 由 RAID 硬件 或 RAID 软件 来 完成 。 但 是 ,RAID0O 不 提供 错误 校 验 功 能 ,所 以 有 人 
说 它 不 能 算 作 是 RAID, 其 实 这 也 是 RAIDO 为 什么 被 称 为 0 级 RAID 的 原因 一 一 0 本 身 
就 代表 “没有 ”。 


表 8-3 RAID 的 分 级 


可 正常 工作 的 
0 


RAIDO “| 无 匈 余 无 校 验 的 磁盘 阵列 

RAID1 ”| 镜像 磁盘 阵列 1 
RAID2 纠 错 汉 明码 磁盘 阵列 ] 
RAID3 位 交叉 奇偶 校 验 的 磁盘 阵列 ] 
RAID4 | 块 交叉 奇偶 校 验 的 磁盘 阵列 ] 
RAID5 无 独立 校 验 盘 的 奇偶 校 验 磁盘 阵列 | 
RAID6 双 维 无 独立 校 验 盘 的 奇偶 校 验 磁盘 阵列 2 


RAID 级 别 的 选择 有 3 个 主要 因素 : 可 用 性 (数据 元 余 ) ,性 能 和 成 本 。 如 果 不 要 求 可 用 
性 ,选择 RAIDO 以 获得 最 佳 性 能 。 如 果 可 用 性 和 性 能 是 重要 的 而 成 本 不 是 一 个 主要 因素 ， 
则 根据 硬盘 数量 选择 RAID1。 如 果 可 用 性 、 成 本 和 人 性 能 都 同样 重要 , 则 根据 一 般 的 数据 传 
输 和 硬盘 的 数量 选择 RAID3、RAID5。 

RAID2 一 RAID6 具有 很 强 的 功能 ,但 毕竟 太 贯 了 ,多 用 于 高 端 服 务 器 。 后 来 又 推出 了 
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RAID 7, 这 是 目前 理论 上 性 能 最 高 的 RAID 模式 ,具有 全 新 的 RAID 架构 ,由 于 其 自身 就 带 
有 实时 操作 系统 和 用 于 存储 管理 的 软件 工具 ,可 完全 独立 于 主机 运行 , 且 不 占用 主机 CPU 
资源 ,所 以 RAID 7 可 以 看 作 一 种 小 型 存储 计算 机 ,与 其 他 RAID 架构 相 比 较 更 为 先进 ,但 
价格 非常 昂贵 。 所 以 ,下面 只 介绍 RAIDO、RAID1, 以 及 由 它们 派生 出 来 的 RAID1 十 0 和 
RAID0O 十 1。 

RAIDO 是 一 个 极端 追求 性 能 的 方案 , 它 至 少 基于 两 个 人 硬盘 ,数据 同时 分 布 在 各 个 硬盘 
上 ,没有 容错 能 力 , 如 图 8-8 所 示 。 可 以 看 出 ,由 于 一 个 传输 过 程 由 多 个 便 盘 分 担 , 也 就 相当 
于 传输 带宽 增加 ,所 以 读 写 速度 在 RAID 中 最 快 。 但 是 ,因为 任何 一 个 便 盘 损坏 都 会 使 整个 
RAID 系统 失效 ,所 以 安全 系数 反倒 比 单个 的 硬盘 还 要 低 。RAID0O 是 舍弃 了 RAID 所 强调 
的 安全 方面 的 要 求 而 得 到 的 极限 性 能 ,一 般 用 在 对 数据 安全 要 求 不 高 但 对 速度 要 求 很 高 的 
场合 下 。 

RAID1 是 为 了 达到 RAID 安全 方面 的 极限 而 诞生 的 。 每 一 个 硬盘 都 有 一 个 镜像 的 硬 
盘 ,镜像 盘 随时 保持 与 原 盘 的 内 容 一 致 ,如 图 8-9 所 示 。 


软件 或 阵列 卡 软件 或 阵列 卡 


硬 米 1 = 硬 


] 


8-8 RAIDO 数据 存放 8-9 ”RAID1 数据 存放 


2 


RAID1 具有 最 高 的 安全 性 ,但 只 有 一 半 的 磁盘 空间 被 用 来 存储 数据 。 主 要 用 在 对 数据 
安全 性 要 求 很 高 ,而 且 要 求 能 够 快速 恢复 被 损坏 数据 的 场合 。 在 这 种 方式 下 ,不 论 原 盘 出 现 
什么 故障 ,都 可 以 从 镜像 盘 恢 复 回 来 ,不 过 显然 浪费 了 一 半 的 磁盘 空间 ,而 且 这 种 情况 下 唯 
一 对 提升 性 能 有 帮助 的 就 是 在 读 取 时 系统 会 同时 从 两 个 盘 上 搜索 ,把 先 读 取 到 的 数据 传输 
回来 。 

虽然 RAID1 也 可 以 获得 少许 的 性 能 提升 ,但 是 相对 RAIDO 来 说 臣 介 是 微不足道 了 。 
因此 ,在 性 能 和 安全 兼顾 的 情况 下 ,就 出 现 了 RAID1 十 0 或 RAID0 十 1]。RAID1 十 0 是 先 镜 
像 再 分 组 ,而 RAID0 十 1 是 先 分 组 再 镜像 。RAID1 十 0 或 RAID0 十 1 都 至 少 使 用 4 个 硬盘 。 
RAID0 十 1 比 RAID1 十 0 有 着 更 快 的 读 写 速度 ,但 可 徘 性 RAID0 十 1 不 及 RAID1 十 0, 这 是 
因为 当 RAID1 十 0 有 一 个 硬盘 受 损 , 其 余 3 个 硬盘 会 继续 运作 ,而 RAID0 十 1 只 要 有 一 个 硬 
盘 受 损 , 同 组 RAID0 的 另 一 个 硬盘 也 会 停止 运作 ,只 剩 下 两 个 硬盘 运作 。 因 此 ,RAID1 十 0 
远 比 RAIDO 二 1 常用 。 


8.5 光盘 存储 器 


相对 于 利用 磁 通 变化 和 磁化 电流 进行 读 写 的 磁盘 而 言 , 用 光学 方式 读 写 信息 的 圆 盘 称 
为 光 副 ,以 光盘 为 存储 介质 的 存储 侣 称 为 光盘 存储 带 。 
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8.5.1 光盘 存储 器 的 类 型 


根据 性 能 和 用 途 的 不 同 , 光 盘存 储 硕 可 分 为 两 类 : 一 类 是 只 读 型 光盘 ,如 CD-ROM.、 
DVD-ROM 、BD-ROM 等 ; 另 一 类 是 可 记录 型 光盘 ,如 CD-R CD-RW、DVD-RAM 等 。 根据 
光盘 结构 的 不 同 , 光 盘 又 可 以 分 为 CD、. DVD .蓝光 光盘 几 种 类 型 。 


1. CD 光盘 


CD 光盘 采用 波长 为 780nm 的 红外 激光 读 取 和 写 入 数据 ,其 容量 在 700MB 左右 。 只 读 
的 CD 光盘 和 可 记录 的 CD 光盘 在 结构 上 并 没有 区 别 。 

(1) CD-ROM 

CD-ROM(Compact Disc Read Only Memory) , 即 只 该 型 光盘 ,又 称 固 定型 光盘 。 它 由 
生产 厂家 预先 写 入 数据 和 程序 ,使 用 时 用 户 只 能 读 出 ,不 能 修改 或 写 入 新 内 容 。 

(2) CD-KR 

CD-R 光盘 采用 WORM(Write One Read Many) 标 准 ,光盘 可 由 用 户 写 入 信息 , 写 入 后 
可 以 多 次 读 出 ,但 是 只 能 写 和 人 一 次 ,信息 写 人 后 将 不 能 再 修改 ,所 以 称 为 只 写 一 次 性 光盘 。 

(3) CD-RW 

这 种 光盘 是 可 以 写 入 、 擦 除 、 重 写 的 可 逆 性 记录 系统 。 这 种 光盘 类 似 于 磁盘 ,可 重复 
读 写 。 


2. DVD 光盘 


DVD(Digital Versatile Disc) 代 表 通 用 数字 光盘 ,又 称 高 容量 CD。DVD 光盘 采用 波长 
为 650nm 的 红色 激光 读 取 和 写 人 数据 ,其 容量 可 以 达到 4. 7GB。DVD 光盘 是 在 CD 光盘 
之 后 的 又 一 次 重要 的 技术 飞跃 , 它 不 仅 在 技术 方面 获得 了 很 大 的 成 功 ,并 且 迅 速 地 推 癌 市 
场 , 成 为 CD 光盘 的 替代 者 。 与 CD 光盘 类 似 ,DVD 光盘 也 可 以 分 为 DVD-R 、 DVD-RW 等 。 


3. 蓝光 盘 


蓝光 盘 (BD) 利 用 波长 较 短 (405nm) 的 蓝 色 激光 读 取 和 写 人 数据 ,并 因此 而 得 名 。 通 篆 
来 说 ,波长 越 短 的 激光 能 够 在 单位 面积 上 记录 或 读 取 更 多 的 信息 。 因 此 ,蓝光 极 大 地 提高 了 
光盘 的 存储 容量 ,容量 可 达 25GB。 蓝 光盘 是 DVD 光盘 之 后 的 下 一 代 光 盘 格 式 之 一 ,用 以 
存储 高 品质 的 影音 以 及 高 容量 的 数据 存储 ,在 不 久 的 将 来 高 密度 蓝光 盘 可 能 会 取代 DVD 
生得， 


8.5.2 光盘 存储 器 的 组 成 及 工作 原理 
1. 光盘 存储 器 的 组 成 


光盘 人 存储 硕 由 光盘 控制 希 和 光盘 驱动 硕 及 接口 组 成 。 

光盘 控制 硕 主 要 包括 数据 输入 缓冲 需 、 记 录 格 式 融 、 编 码 硕 、 读 出 格式 项 和 数据 输出 组 
冲 句 等 部 分 。 

光盘 驱动 帮主 要 包括 主轴 电机 驱动 机 构 、 定 位 机 构 、 光 涉 泪 置 及 电路 等 。 其 中 ,光头 汇 
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置 部 分 最 为 复杂 ,是 驱动 器 的 关键 部 分 。 

光盘 片 是 指 整个 盘 片 , 盘 片 主要 包 插 基板、 记录 层 、 反 射 层 、 保 护 层 、 印 刷 层 5 层 。 

基板 一 般 末 用 聚 碳酸 酯 晶片 制 成 ,是 一 种 耐 热 的 有 机 玻璃 。 无 论 是 CD-ROM、DVD- 
ROM ,还 是 CD-R、CD-RW 光盘 ,表面 上 看 都 是 一 张 120mm 直径 的 盘 片 , 中 心 有 一 个 供 固 
定 用 的 15mm 直径 小 圆 孔 , 环 孔 中 心 半 径 13. 5mm 范围 内 和 盘 片 外 沿 1mm 内 是 空 月 区 , 真 
正 存放 数据 的 便 是 中 间 一 段 宽度 为 38mm 的 环形 区 域 。 

记录 层 又 称 染 料 层 ,以 供 激光 记录 信息 。 各 种 类 型 光盘 的 不 同 之 处 主要 是 记录 层 的 化 
学 成 分 存在 差异 。 例 如 ,CD-R 光盘 涂抹 专用 的 有 机 染料 ,而 CD-RW 光盘 则 涂抹 某 种 碳 性 
物质 。 

反射 层 是 反射 激光 光束 的 区 域 , 借 反射 的 激光 光束 读 取 光盘 片 中 的 信息 。 光 线 到 达 此 
层 ,就 会 反射 回去 。 

保护 层 用 来 保护 光盘 中 的 反射 层 和 记录 层 , 防 止 信息 被 破坏 。 印 刷 层 不 仅 可 以 标明 光 
盘 的 内 容 , 还 可 以 起 到 一 定 的 保护 光盘 的 作用 。 


2. CD-ROM 光盘 的 制作 和 读 取 


CD-ROM 光盘 是 采用 母 盘 灌 制 的 方法 大 批量 生产 的 。 首 先 用 事先 编制 好 的 程序 控制 
激光 刻 片 机 ,对 一 张 玻璃 基板 进行 蚀刻 ,将 要 存储 的 数据 内 容 在 玻璃 基板 上 形成 一 个 个 数据 
凹 痕 , 这 个 制作 完成 的 玻璃 基板 就 是 大 量 压 制 CD-ROM 光盘 的 模具 。 模 具 制 造 完 成 之 后 ， 
用 聚 碳酸 酯 炊 液 倒 和 模具 中 ,冷却 后 便 变 成 具有 同 玻璃 基板 相应 凹 槽 的 基 片 ,在 其 表面 喷 有 
一 层 厚 度 约 为 50nm 的 铝 质 反光 涂料 ,其 作用 就 是 将 读 取 数据 的 激光 反射 给 接收 装置 ;此 外 
还 必须 覆盖 一 层 起 保护 作用 的 透明 基 片 ,这 样 盘 片 的 制作 就 完成 了 。 

CD-ROM 光盘 上 有 一 条 从 内 问 外 的 由 四 痕 和 平坦 表面 相互 交替 而 组 成 的 连续 的 螺旋 
形 路 径 ,如 图 8-10 所 示 。 也 就 是 说 ,数据 和 程序 都 是 以 刻 痕 的 形式 保存 在 盘 片 上 的 。 当 一 
束 激光 照射 在 盘面 上 , 靠 盘 面 上 有 无 凹 痕 的 不 同 反射 率 来 读 出 程序 和 数据 。 因 为 程序 和 数 
据 文件 是 按 内 螺旋 线 的 规律 顺序 存放 在 盘 上 的 ,不 能 像 磁 盘 驱 动 器 那样 读 取 文 件 的 每 个 扇 
区 ,所 以 读 出 速度 较 慢 。 


数据 区 蝶 旋 型 
数据 轨道 


图 8-10 ” ”CD-ROM 光盘 


问 肥 和 于 。 
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当 光 驱 读 取 这 些 盘 片 时 ,激光 头 射出 的 激光 束 在 穿 过 表面 的 透明 基 片 后 ,直接 聚焦 在 盘 
片 反 射 层 上 ,被 反射 回来 的 激光 会 被 光 感 应 需 检 测 到 。 每 当 激 光 通 过 目 雏 时 光 强 会 发 生变 
化 ,代表 读 取 到 数据 *1”; 而 激光 通过 平坦 表面 时 光 强 不 发 生变 化 , 则 代表 读 取 到 数据 "0”。 
光驱 的 信号 接收 系统 则 负责 把 这 种 光 强 的 变化 转换 成 相应 的 电信 号 再 传送 到 系统 总 线 , 从 
而 实现 数据 的 读 取 。 


3. CD-R 光盘 的 读 写 原 理 


CD-R 光盘 的 写 入 是 利用 聚焦 成 lym 左右 的 激光 束 的 热能 使 记录 介质 表面 的 形状 发 生 
永久 性 变化 而 完成 的 ,所 以 只 能 写 入 一 次 ,不 能 抹 除 和 改写 。 

计算 机 送 来 的 数据 , 先 在 光盘 控制 硕 内 调制 成 记录 序列 ,然后 变 成 相应 的 记录 脉冲 信 
号 。 该 脉冲 信号 在 电流 驱动 电路 内 变 为 电流 , 送 到 激光 器 。 激 光 需 以 20mW 左右 的 功率 发 
光 ,并 聚焦 成 lum 左右 的 微小 光 点 , 落 在 记录 介质 表面 上 ,CD-R 光盘 上 有 一 个 有 机 染料 刻 
录 层 ,激光 可 以 对 该 层 的 一 个 微小 的 区 域 加 热 , 烧 透 染 料 层 使 其 不 透明 , 即 打出 一 个 微米 级 
的 四 坑 。 有 四 坑 代 表 写 入 “1”, 无 四 坑 代 表 写 入 “0”。 四 坑 将 永久 性 地 保持 现状 意味 着 此 种 
光盘 只 能 一 次 写 入 。 

读 出 时 ,用 比 写 入 功率 低 的 激光 束 ( 约 几 毫 瓦 ) ,连续 照射 在 光盘 上 。 由 于 有 四 坑 处 的 反 
射 光 弱 ,无 凹 坑 处 的 反射 光 强 ,根据 这 一 原理 , 当 激 光照 射 到 光盘 后 ,由 光 检 测 需 将 介质 表面 
反射 率 的 变化 转变 为 电信 号 ,经 过 数据 检测 . 译 码 后 送 入 计算 机 中 , 即 可 读 出 光盘 上 记录 的 
信息 。 由 于 读 出 光束 的 功率 仅 是 写 信 光束 功率 的 1/10, 因 此 不 会 熔 出 新 的 凹 坑 。 

CD-R 的 盘 片 有 金 碟 、 绿 碟 、 蓝 碟 3 种 ,它们 主要 因 记 录 层 和 反射 层 采 用 的 材料 不 同 而 
呈现 出 不 同 的 颜色 。 


4. CD-RW 光盘 的 读 写 原理 


CD-RW 光盘 是 利用 激光 照射 引起 记录 介质 的 可 逆 性 物理 变化 来 进行 读 写 的 ,光盘 上 
有 一 个 相位 变化 刻录 层 , 所 以 CD-RW 光盘 又 称 为 相 变 光盘 ，。 

相 变 光盘 的 读 写 原理 是 利用 存储 介质 的 品 态 . 非 品 态 可 逆转 换 , 引 起 对 和 人 射 激光 束 不 同 
强度 的 反射 (或 折射 ) ,形成 信息 一 一 对 应 的 关系 。 

写 和 人 时 ,利用 高 功率 的 激光 聚焦 于 记录 介质 表面 的 一 个 微小 区 域内 ,使 唱 态 在 吸 热 后 至 
熔点 ,并 在 激光 束 离开 瞬间 又 冷 转 变 为 非 晶 态 , 信 息 即 被 写 入 。 

读 出 时 ,由 于 品 态 和 非 品 态 对 入 射 激光 束 存 在 不 同 的 反射 和 折射 率 , 利 用 已 记录 信息 区 域 
的 反射 与 周围 未 发 生 唱 态 改变 区 域 的 反射 之 间 存 在 着 明显 反差 的 效应 ,将 所 记录 的 信息 读 出 。 

擦 除 时 ,利用 适当 波长 和 功率 的 激光 作用 于 记录 信息 点 ,使 该 点 温度 介 于 材料 的 熔点 和 
非 唱 态 转变 温度 之 间 ,使 之 产生 重 结 唱 而 恢复 到 唱 态 ,完成 擦 除 功 能 。 

可 写 的 CD-R、CD-RW 的 母 盘 制作 过 程 大 致 是 相同 的 ,它们 也 都 是 采用 激光 刻 片 机 蚀 
刻 玻璃 基板 。 不 过 因为 没有 存放 数据 ,对 玻璃 基板 不 作 凹 权 的 蚀刻 ,而 只 是 利用 程序 的 精密 
控制 来 刻 出 螺旋 状 轨 迹 。 模 具 制 造 完 成 后 再 用 聚 碳酸 酯 生产 塑胶 基 片 , 喷 上 铝 或 钛 的 反射 
涂 层 ;为 了 实现 数据 写 人 ,CD-R 和 CD-RW 盘 片 还 必须 再 喷涂 上 一 层 对 激光 敏感 的 化 学 物 
质 , 当 CD-R 或 CD-RW 刻写 数据 时 ,高 强度 的 激光 会 令 这 些 物质 发 生物 理 变 形 或 化 学 变 
性 ,产生 许多 存储 数据 的 止 痕 , 以 此 实现 数据 的 写 入 。 
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5. DVD 光盘 的 工作 原理 


才 co 测 


DVD 采用 与 CD 类 似 的 技术 ,只 是 采用 了 波长 更 短 的 激光 束 (650nm) 来 读 写 数据 。 
DVD-ROM 的 读 取 过 程 与 CD-ROM 相似 ,从 盘 上 读 信息 是 将 一 个 低能 的 激光 束 从 光 ” 
盘 上 各 层 的 反射 层 反射 回来 的 过 程 。 激 光 从 盘 的 下 方 发 射 一 束 激光 , 若 该 激光 反射 回来 , 光 
敏 接 收 器 就 会 感应 到 ;如 果 激 光 遇 到 的 是 平地 , 它 就 会 被 反射 回来 ;如 果 激 光 遇 到 的 是 凹陷 
不 平 的 地 方 , 就 没有 激光 返回 。 
可 写 式 DVD 包括 DVD-R 、 DVD-RAM DVD-RW 和 DVD 十 RW,DVD-R 是 一 种 类 似 
于 CD-R 的 一 次 写 介 质 , 其 他 几 种 可 写 式 使 用 了 相位 变化 技术 。 
DVD 每 面 可 以 有 两 层 用 来 刻录 数据 ,每 一 层 单独 压制 ,然后 结合 到 一 起 最 终 形成 
1.2mm 厚 的 光盘 。 与 CD 一样 ,DVD 每 一 层 都 是 以 单一 的 螺旋 形 路 径 的 形式 印 制 ,从 光盘 
的 最 里 端 开始 向 外 环绕 。 螺 旋 形 路 径 上 包含 与 CD 中 相同 的 止 痕 和 平地 。 每 一 层 都 覆盖 一 
层 反 射 激 光 的 金属 膜 ;外 层 的 金属 膜 较 薄 , 以 便 激 光 穿 过 它 读 取 里 层 的 数据 。 


6. BD 光盘 的 工作 原理 


蓝 色 激光 的 波长 仅 为 405nm, 较 小 的 光束 聚焦 更 精确 ,最 小 凹 坑 长 度 只 有 0. 15xm(DVD 
的 最 小 四 坑 长 度 为 0. 4pm) ,螺旋 线 的 轨 距 只 有 0. 32um(DVD 的 轨 距 为 0.74um)。 更 小 的 光 
束 、 更 小 的 四 坑 以 及 更 短 的 轨 距 结合 起 来 ,使 得 单 层 BD 光盘 的 容量 大 约 是 DVD 的 5 倍 。 

BD 光盘 的 厚度 与 DVD 大 致 相同 ,但 两 种 光盘 存储 数据 方式 并 不 相同 。 在 DVD 中 , 数 
据 存 放 在 两 个 0.6mm 基 片 上 ,可 能 会 导致 双 折 射 问 题 ,使 光盘 无 法 读 取 ;而 BD 光盘 将 数据 
存放 在 1. 1mm 厚 的 基 片 上 ,可 以 防止 双 折 射 , 克 服 了 DVD 的 读 取 问题 。 

目前 DVD 的 数据 传输 率 为 10Mb/s,BD 光盘 的 数据 传输 率 可 达 36Mb/s。 


7. 光盘 读 取 技术 


CLV(Constant Linear Velocity) 技 术 , 即 恒定 线 速 度 读 取 方式 。 这 是 在 低 于 12 倍速 的 
光驱 中 使 用 的 技术 。 它 是 为 了 保持 数据 传输 率 不 变 , 而 随时 改变 旋转 光盘 的 速度 。 谈 取 内 
着 数据 的 旋转 速度 比 外 部 要 快 许 多 。 

CAV(Constant Angular Velocity) 技 术 , 即 恒定 角速度 谈 取 方式 。 它 是 用 同样 的 速度 
来 谈 取 光盘 上 的 数据 。 但 光盘 上 的 内 道 数据 比 外 着 数据 传输 速度 要 低 , 越 往外 越 能 体现 光 
驱 的 速度 。 

CLYV 与 CAYV 技术 参数 的 比较 如 表 8-4 所 示 。 而 PCAV(CPartial-CAV) 技 术 是 融合 了 
CLV 和 CAYV 的 一 种 技术 , 称 为 区 域 恒 定 角速度 谈 取 方式 。 它 是 在 读 取 外 着 数据 时 采用 
CLYV 技术 ,在 读 取 内 道 数据 时 采用 CAV 技术 ,从 而 提高 了 整体 数据 传输 的 速度 。 

表 8-4 CLV 与 CAV 技术 参数 的 比较 


技术 参数 CLV( 和 恒定 线 速度 ) CAV( 恒 定 角 速度 ) 


光驱 转速 内 道 快 于 外 道 恒定 
数据 传输 率 恒定 外 道 高 于 内 道 
噪声 水 平 高 低 
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8.5.3 光盘 有 驱动 器 


1. CD-ROM 驱动 器 


自 1982 年 第 一 台 CD-ROM 驱动 器 问世 以 来 ,数据 传输 率 已 经 成 为 其 更 新 换代 的 标志 。 
数据 传输 率 是 以 150KB/s 为 基准 成 倍增 加 的 。 因 此 ,习惯 上 把 150KB/s 传输 率 的 光驱 称 为 
单 倍速 光驱 ,而 把 300KB/s 传输 率 的 光驱 称 为 双 售 速 (2X) 光 驱 , 其 后 的 四 售 速 (4X) 光 驱 、 
八 倍速 (8X) 、32 倍速 (32X) 光 驱 等 也 由 此 而 得 名 ,如 今 市 面 上 已 有 56 倍速 或 更 高 的 CD- 
ROM 驱动 需 。 

一 个 光驱 仅仅 是 传输 率 高 还 不 够 ,还 应 该 配 有 足够 的 数据 缓冲 区 ,数据 缓冲 区 大 的 光 豫 
在 读 小 型 文件 和 随机 文件 时 效果 非常 明显 。 

光驱 的 速度 虽然 在 不 断 地 “提升 ”, 但 从 某 种 角度 而 言 ,这 只 不 过 是 光驱 厂商 玩弄 的 数字 
游戏 而 已 。 理 论 上 讲 32X 光驱 的 速度 应 该 是 8X 光驱 的 4 倍 , 但 实际 速度 的 提升 却 并 不 明 
显 ,实际 测试 最 多 不 超过 2 倍 。 这 是 什么 原因 呢 ? 前 面 已 经 提 到 ,12 倍速 以 下 的 光驱 一 般 
采用 CLYV 技术 ,在 这 种 技术 中 ,CD-ROM 会 根据 现在 正在 读 取 的 是 光盘 外 道 数据 还 是 内 道 
数据 来 控制 电机 以 不 同 的 角速度 旋转 光盘 , 读 内 道 数 据 时 光盘 转速 快 , 读 外 道 数 据 时 光盘 转 
速 慢 ,这 样 就 能 够 保证 在 盘 片 的 不 同 区 域内 保持 恒定 的 数据 传输 率 ,并 且 对 光盘 的 纠 错 性 能 
也 能 有 一 定 的 提高 。 但 是 ,在 光驱 速度 进一步 提高 之 后 ,如 果 仍 采用 CLA 技术 ,电机 将 在 
高 速 的 旋转 下 ,不 断 地 改变 速度 以 保证 在 不 同 的 内 、 外 光 道 时 线 速度 仍然 相同 ,这 将 使 电机 
的 老化 加 剧 。 为 了 解决 上 述 问 题 , 对 于 12 倍速 以 上 的 高 速 光 驱 采 用 了 CAYV 技术 。 此 时 ， 
光驱 主轴 的 转速 是 恒定 的 ,由 于 在 光盘 外 道 读 取 的 数据 要 比 内 道 多 ,所 以 外 道 的 数据 传输 率 
高 于 内 道 的 数据 传输 率 。 现 在 光驱 厂商 所 标 称 的 多 少 倍速 ,实际 上 是 指 在 读 取 光盘 外 道 时 
的 最 大 速度 ,而 从 平均 速度 来 看 当然 就 没有 那么 高 了 。 高 倍速 的 光驱 对 只 在 内 圈 上 有 数据 
的 光盘 而 言 意 义 不 大 (很 多 光盘 上 的 信息 都 并 没有 做 满 ) 。 


2. CD-R 光驱 


由 于 CD-R 光驱 可 以 对 光盘 写 和 人 ,因此 也 称 为 光盘 刻录 机 。 光 盘 刻录 机 的 速度 有 读 取 
速度 和 写 人 速度 ,而 后 者 才 是 刻录 机 的 重要 技术 指标 。 在 实际 的 谈 取 和 写 人 时 ,由 于 光盘 的 
质量 和 烧 录 的 稳定 度 下 降 , 读 取 的 速度 会 下 降 , 烧 录 的 速度 也 会 下 降 。 其 次 应 该 注意 数据 组 
冲 区 的 大 小 ,缓冲 区 的 大 小 是 衡量 刻录 机 的 重要 指标 之 一 。 因 为 在 烧 录 时 数据 要 先 写 入 绥 
冲 区 上 青 去 烧 录 ,如 果 缓 冲 区 中 的 数据 用 完了 ,而 后 面 的 数据 又 没 能 及 时 补充 上 来 , 烧 录 当然 
就 失败 了 。 所 以 ,缓冲 区 越 大 , 烧 录 的 成 功率 就 越 高 ,目前 市 场 上 光盘 刻录 机 的 缓冲 区 一 般 
在 512KB 一 4MB。 


3. CD -RW 光驱 


CD-RW 光驱 又 称 可 擦 写 光 盘 刻 录 机 ,第 一 个 CD-RW 光驱 标注 为 2/2/6, 即 其 刻录 速 
率 为 两 倍速 . 重 写 速率 为 两 倍速 . 读 速 率 为 6 倍速 ,目前 已 经 有 20/10/40 的 版 本 出 现 。 

CD-RW 光驱 可 代替 大 部 分 的 CD-R 光驱 ,因为 CD-RW 光驱 与 CD-R 完全 兼容 ,并 能 
以 同样 的 能 力 读 写 通用 的 CD-R 介质 。CD-RW 光盘 的 烧 制 或 刻录 的 方式 也 与 CD-R 光盘 


外部 设备 


相同 ,主要 区 别 在 于 它们 可 以 擦 除 掉 而 多 次 重 写 , 重 写 次 数 可 以 达 1000 多 次 。 
4. DVD 光驱 


DVD 光驱 指 读 取 或 刻录 DVD 光盘 的 设备 ,事实 上 ,任何 DVD 光驱 都 是 CD 光驱 , 即 这 
类 光驱 既 能 读 取 CD 光盘 ,也 能 读 取 DVD 光盘 。DVD 除了 密度 较 高 以 外 ,其 他 技术 与 
CD-ROM 完 全 相同 。 目 前 的 DVD 光驱 多 采用 IDE 或 SATA 接口 ,这 意味 着 DVD 光驱 能 
像 硬盘 一 样 连接 到 主板 的 IDE 或 SATA 接口 上 。 

DVD 光驱 的 实际 旋转 速度 大 约 为 同样 倍速 的 CD 光驱 的 3 倍 。 许 多 DVD-ROM 光驱 
列 出 了 两 个 速度 ,一 个 是 读 取 DVD 盘 的 速度 , 男 一 个 是 读 取 CD 盘 的 速度 。 例 如 , 某 
DVD-ROM 光 驱 的 速度 为 16X/40X, 这 分 别 指 的 是 读 DVD 和 CD 盘 的 性 能 。 


5. BD 光驱 


BD 光驱 是 能 读 取 或 刻录 蓝光 光盘 的 光驱 ,向 下 兼容 DVD、CD 格式 。BD 光驱 有 内 置 
和 外 置 之 分 ,内 置 BD 光驱 多 采用 SATA 接口 ,外 置 BD 光驱 则 采用 USB 接口 。 


8.6 ”新 型 辅助 存储 蕴 


随 看 操作 系统 和 应 用 软件 的 逐渐 庞大 ,需要 更 多 的 空间 来 存储 它们 及 其 创建 的 数据 。 
除去 前 述 的 磁 介 质 存 储 融 和光 存储 融 ,近年 来 又 出 现 了 许多 新 型 的 辅助 存储 天 ,这 些 存 储 姑 
的 共同 特点 是 容量 大 、 可 移动 .使 用 方便 。 所 谓 可 移动 ,是 指 人 存储 天 可 随身 携带 ,便于 存储 ， 
可 以 在 不 同 终端 间 移 动 , 币 见 的 可 移动 存储 硕 使 用 磁 介 质 、 磁 光 介 质 或 电子 郑 件 来 存储 
信息 。 

可 移动 存储 絮 可 以 存储 硅 干 个 数据 文件 或 不 常 使 用 的 程序 ,也 可 以 存储 整个 硬盘 的 内 
容 。 除 了 备份 ,它们 还 可 以 非常 容易 地 将 庞大 的 数据 文件 从 一 台 计 算 机 传递 到 另 一 台 计 算 
机 中 ,或 者 用 户 可 以 将 机 密 数 据 沪 入 可 移动 存储 带 并 将 其 市 离 办 公 室 , 以 防 泄露 。 


8.6.1 基于 磁 或 磁 光 介质 的 可 移动 存储 器 


基于 磁 介 质 可 移动 存储 右 有 两 种 基本 类 型 .磁盘 和 磁 市 。 人 磁盘 介质 的 价格 相对 较 呈 ,其 
容量 一 般 来 说 也 相对 较 小 ,在 基于 文件 的 系统 中 更 容易 使 用 ,在 复制 少量 文件 时 比较 快 ,但 
在 复制 大 量 文件 或 者 整个 驱动 带 时 则 比较 慢 。 磁 带 介 质 的 价格 总 体 来 说 比较 便宜 ,其 总 容 
量 也 比较 大 ,在 图 像 或 多 文件 系统 中 使 用 比较 方便 ,用 它 来 备份 整个 硬盘 上 的 所 有 应 用 程序 
和 数据 非常 合适 , 即 适 合 于 巨 量 备份 ,但 复制 单个 文件 时 就 显得 比较 费事 了 。 

有 两 类 常用 的 可 移动 磁盘 驱动 带 ,分别 基于 磁 介 质 和 磁 光 介质 。 磁 介质 驱动 右 采 用 与 
软盘 或 便 盘 驱动 带 非 常 相似 的 技术 ,对 数据 进行 编码 和 存储 。 磁 光 介质 驱动 带 在 盘 上 对 信 
息 进 行 编码 时 ,使 用 了 磁 和 激光 相 结 合 的 新 技术 。 


1. 移动 硬盘 


绝 大 多 数 移动 硬盘 尺寸 为 2. 5in 或 3. 5in, 只 有 很 少 部 分 是 微型 便 盘 (1. 8in)。 目 前 , 移 
动 便 盘 的 容量 已 经 很 大 (可 以 从 几 百 吉 字 市 到 几 个 太 字 节 ), 随 着 技术 的 发 展 ,移动 硬盘 容量 


oo 
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越 来 越 大 ,体积 越 来 越 小 。 

移动 硬盘 大 多 采用 USB、IEEE 1394 或 eSATA 接口 ,能 提供 较 高 的 数据 传输 速度 。 一 
般 移动 硬盘 由 一 个 USB 接口 供电 就 可 以 了 ,但 也 有 些 移动 硬盘 使 用 一 根 3 个 分 文 的 数据 
线 , 其 中 一 个 分 支 用 于 供电 不 足 时 补充 供电 。 通 常 ,移动 硬盘 应 具有 防震 功能 ,在 剧烈 震动 
时 盘 片 自动 停 转 并 将 磁头 复位 到 安全 区 ,防止 盘 片 损坏 。 


2. 大 容量 软盘 


传统 的 软盘 由 于 容量 小 .速度 慢 、 不 稳定 ,已 逐步 退出 市 场 , 在 此 之 后 大 容量 软盘 (主要 
有 Zip 和 LS-120) 开 始 争夺 市 场 的 主导 地 位 。 但 是 , 随 着 传统 3. 5 in 的 软盘 的 完全 消失 ,这 
两 种 大 容量 软盘 存在 的 必要 性 也 基本 消失 了 。 不 过 它们 毕竟 在 辅助 存储 器 的 发 展 史 上 有 过 
痕迹 ,所 以 在 此 还 是 为 它们 留 下 一 笔记 忆 。 

第 一 代 Zip 磁盘 的 容量 约 100MB ,是 传统 软盘 容量 (1.44MB) 的 70 倍 ; 使 用 并 行 接口 ; 
Zip 驱动 需 采 用 人 硬盘 磁头 技术 (磁头 不 接触 式 读 写 ) , 读 写 速度 快 , 是 传统 软盘 驱动 器 的 20 
倍 ; 最 特别 的 是 ,每 张 Zip 盘 片 都 有 密码 设置 功能 。 随 着 技术 的 发 展 ,到 Zip 750 已 达到 了 
750MB 的 容量 ,使 用 USB 2. 0 接口 ,无 论 是 容量 还 是 速度 都 得 到 了 巨大 的 改善 。 但 遗憾 的 
是 , 它 不 能 兼容 传统 的 软盘 ,导致 Zip 磁盘 应 用 受到 局 限 。 

LS-120 磁盘 存储 容量 为 120MB ,而 且 LS-120 驱动 器 可 以 向 下 兼容 传统 的 软盘 驱动 器 。 
在 同样 的 盘 片 面积 上 能 达到 如 此 高 的 容量 ,这 是 因为 采用 了 一 些 新 的 技术 ,例如 : 

Q 光学 定位 技术 。 传 统 的 软驱 使 用 磁性 定位 ,准确 度 不 高 ,1. 44MB 软盘 只 有 80 条 磁 
道 , 而 采用 激光 光学 定位 技术 之 后 ,在 相同 面积 内 划分 出 更 多 的 磁道 ,可 以 达到 1736 条 
磁道 。 

@ ZBR( 圆 周 位 记录 ) 技 术 ,也 就 是 前 述 的 硬盘 分 区 域 记录 方式 。 传 统 的 软驱 读 写 头 不 
够 灵敏 ,所 以 每 条 磁道 上 扇 区 数 都 是 18 个 ,而 现在 最 内 圈 磁 道 有 51 个 岂 区 ,最 外 圈 磁 道 则 
高 达 92 个 扇 区 。 

以 往 的 软盘 盘 片 材质 已 不 能 负担 如 此 高 密度 的 磁道 数 和 忆 区 数 ,需要 采用 一 种 高 密度 
金属 粒 涂料 来 作为 存储 介质 。 


3。 磁 光盘 


磁 光 盘 又 称 MO(Magnet Optical) 盘 ,这 是 一 种 采用 激光 和 磁场 共同 作用 的 磁 光 方式 存 
储 技术 。 磁 光盘 既 具 硬盘 的 大 容量 和 可 读 写 功能 ,又 有 软盘 的 便携 特性 ,同时 具有 光盘 防 
磁 、 抗 温和 可 靠 的 特征 ,因而 受到 业界 注目 。 磁 光盘 的 记录 层 很 注 , 采 用 对 温度 极为 敏感 的 
磁性 材料 制 成 ,这 些 磁性 材料 在 高 温 下 可 以 被 磁化 。 

磁 光 盘 从 1989 年 开始 投入 使 用 ,是 传统 的 磁盘 技术 与 现代 的 光学 技术 结合 的 产物 。 磁 
光盘 的 外 形 与 传统 软盘 差不多 ,但 容量 比 软盘 大 得 多 ,3. 5in 的 磁 光 盘 容量 可 以 达到 
1. 3GB, 可 重复 读 写 一 千 万 次 以 上 ,携带 方便 ,是 保存 寿命 长 达 50 年 以 上 ,因此 在 存储 图 形 、 
图 像 文件 .大 型 数据 库 文件 方面 起 着 重要 的 作用 。 但 磁 光 盘 的 致命 缺点 是 不 能 用 普通 光驱 
读 出 。 

磁 光 盘 所 用 的 磁 层 中 存在 着 许多 已 磁化 的 磁 畴 , 磁 上 畴 的 磁化 方向 与 介质 表面 垂直 。 初 
始 时 ,在 外 界 磁 场 的 作用 下 ,全 部 磁 畴 转 癌 同一 方向 。 当 数据 写 和 人 时 ,利用 凸透镜 进行 聚焦 ， 
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将 高 功率 激光 照射 在 MO 盘 记 录 层 上 形成 极 小 的 光 点 , 当 此 点 的 温度 上 升 到 约 300%C( 居 里 
点 ) 时 , 磁 畴 随 外 磁场 的 作用 而 改变 其 原 磁 化 方向 。 激 光 迅 速 移 去 后 , 磁 畴 温度 恢复 正常 , 数 
据 被 保存 在 MO 盘 上 。 

所 谓 居 里 温度 ,是 指 材料 可 以 在 铁 磁 体 和 顺 磁 体 之 间 改 变 的 温度 。 当 温度 低 于 居 里 温 
度 时 ,该 物质 称 为 铁 磁体 ,此 时 材料 的 磁场 很 难 改变 ; 当 温 度 高 于 居 里 温度 时 ,该 物质 称 为 顺 
磁体 ,这 时 材料 的 磁场 很 容易 随 周围 磁场 的 改变 而 改变 。 

数据 的 读 取 是 利用 低 功 率 的 激光 探测 盘 片 表面 ,通过 分 析 反 射 回来 的 偏振 光 的 偏振 面 
方 问 是 顺 时 针 还 是 逆 时 针 ,来 决定 谈 取 的 数据 是 “17 还 是 "0”。 

要 进行 数据 重 写 时 ,必须 经 过 “ 擦 ” 和 “ 写 ” 两 步 : 首先 利用 中 功率 激光 照射 拟 擦 除 的 位 
置 ,使 磁 畴 翻转 恢复 到 原来 的 方向 , 即 通 过 写 人 “0” 来 抹 去 原 存 数据 ;然后 再 根据 要 求 用 高 功 
率 激光 在 需要 的 位 置 写 入 数据 "1”, 这 样 就 完成 了 数据 的 重 写 。 


4. 磁带 


磁带 的 位 价格 要 比 磁盘 便宜 很 多 ,整体 容量 也 大 一 些 。 磁 带 是 顺序 访问 的 ,用 户 要 找 一 
个 文件 ,必须 从 磁带 头 开始 ,而 且 不 能 单独 修改 或 移动 磁带 上 的 单个 文件 ,必须 将 整 盒 磁带 
的 内 容 删除 ,然后 再 全 部 重 写 。 因 此 ,磁带 比较 适合 作为 整个 硬盘 程序 和 数据 的 备份 存储 
器 , 即 大 容量 的 备份 存储 。 

计算 机 上 要 备份 的 数据 、 要 存储 的 档案 可 能 需要 大 量 空间 ,一 些 用 户 每 星期 其 至 每 天 都 
需要 备份 他 们 的 数据 ,即将 这 些 数 据 转 移 到 别 的 存储 介质 上 ,以 便 为 机 器 留 出 更 多 的 磁盘 
空间 。 

备份 整个 人 硬盘 数据 或 修改 数据 的 传统 方法 是 使 用 磁带 ,如果 磁带 容量 足够 大 ,用 磁带 备 
份 整 个 人 硬盘 的 数据 是 最 简单 .最 有 效 的 方法 。 在 机 器 上 装 一 个 用 于 备份 的 磁带 机 ,在 机 器 里 
插入 一 卷 磁带 ,选择 要 备份 的 驱动 顺和 文件 ,然后 开始 备份 ,备份 软件 就 开始 将 要 备份 的 数 
据 往 磁带 上 复制 ,而 用 户 就 可 以 干 别 的 事 去 了 。 以 后 要 修改 磁带 上 的 部 分 或 全 部 数据 时 ,将 
这 盒 磁 带 插 和 磁带 机 ,启动 备份 程序 ,选择 需要 重新 存 人 的 文件 , 剩 下 的 工作 就 由 磁带 机 来 
做 了 。 

自动 加 载 磁 带 机 是 一 个 位 于 单机 中 的 磁带 驱动 器 和 自动 磁带 更 换 装 置 , 它 可 以 从 装 有 
多 盘 磁 带 的 磁带 车 中 拾取 磁带 并 放 入 驱动 器 中 ,或 者 执行 相反 的 过 程 。 自 动 加 载 磁 带 机 能 
够 支持 例 行 备 份 过 程 ,自动 为 每 日 的 备份 工作 装载 新 的 磁带 。 一 个 拥有 工作 组 服务 器 的 小 
公司 可 以 使 用 自动 加 载 机 来 自动 完成 备份 工作 。 

磁带 库 是 像 自 动 加 载 磁 带 机 一 样 基于 磁带 的 备份 系统 ,磁带 库 由 多 个 驱动 器 、 多 个 槽 、 
机 械 手 臂 组 成 ,并 可 巾 机械 手臂 自动 实现 磁带 的 拆卸 和 装填 。 它 能 够 提供 同样 的 基本 自动 
备份 和 数据 恢复 功能 ,但 同时 具有 更 先进 的 技术 特点 。 它 可 以 多 个 驱动 器 并 行 工 作 , 也 可 以 
几 个 驱动 硕 指 回 不 同 的 服务 需 来 做 备份 ,存储 容量 达到 PB 级 (1P 二 2”) ,可 实现 连续 备份 、 
自动 搜索 磁带 等 功能 ,并 可 在 管理 软件 的 支持 下 实现 智能 恢复 、 实 时 监控 和 统计 ,是 集中 式 
网 络 数据 备份 的 主要 设备 。 


8.6.2 基于 电子 器 件 的 存储 器 
基于 电子 器 件 的 闪存 卡 、 固 态 硬盘 和 U 盘 与 磁盘 .光盘 等 传统 存储 产品 相 比 表 现 出 更 
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为 旺盛 的 生命 力 。 
1. 闪存 卡 


闪存 卡 是 利用 闪存 (Flash Memory) 技 术 存 储 信 息 的 存储 器 , 它 是 数码 相机 的 最 好 搭 
档 , 所 以 也 被 称 为 数字 “胶卷 ”, 和 普通 的 胶卷 不 同 , 它 可 以 被 擦 除 , 然 后 可 重新 使 用 。 对 于 内 
存 卡 来 说 ,最 重要 的 指标 是 容量 ,其 次 是 读 写 速度 。 写 入 速度 高 意味 着 数码 相机 可 以 迅速 地 
把 拍摄 的 数据 传送 到 闪存 卡 中 ,准备 好 进行 下 一 次 拍摄 。 读 出 速度 高 的 闪存 卡 可 以 缩短 图 
像 数 据 上 传 到 计算 机 所 需 的 时 间 。 

闪存 卡 是 相当 特殊 的 存储 介质 ,从 接口 规范 和 使 用 来 看 , 它 就 像 一 块 外 置 硬 盘 , 但 在 内 
部 ,半导体 存储 器 的 特性 相当 突出 。 根 据 不 同 的 生产 厂商 和 不 同 的 应 用 ,内 存 卡 有 CF 卡 、 
SM 卡 、 记 忆 棒 、MMC 卡 、SD 卡 、xD 卡 和 微 硬盘 7 类。 这些 闪存 卡 虽然 外 观 、 规 格 不 同 , 但 
是 技术 原理 都 是 相同 的 。 

(1) CF 卡 

CF(Compact Flash) 卡 曾经 是 闪存 阵营 中 的 “老大 ”,CEF 卡 上 内 置 了 ATA/IDE 控制 
需 , 具 备 即 插 即 用 功能 ,可 以 兼容 绝 大 部 分 操作 系统 。CF 是 最 老 也 是 最 成 功 的 闪存 标准 之 
一 ,尤其 适合 专业 相机 市 场 。 

(2) SM 卡 

SM(SmartMedia) 卡 又 称 为 固态 软盘 卡 (SSFDC), 大 小 与 CF 卡 相似 ,与 CF 卡 不 同 之 
处 在 于 没有 内 置 控制 器 ,控制 器 集成 在 数码 产品 中 ,目前 的 数码 产品 已 很 少 采 用 SM 卡 。 

(3) 记忆 棒 

从 外 形 上 看 ,标准 的 记忆 棒 比 一 块 口香糖 略 小 , 它 采 用 排列 在 单 侧 的 10 针 接 口 与 驱动 
融 连 接 。 

(4) MMSC 卡 

MMC 卡 在 SM 卡 基础 上 诞生 又 很 快 地 替代 了 SM 卡 。MMC 也 把 控制 器 一 同 做 到 卡 
上 ,智能 的 控制 器 使 得 MMC 保证 兼容 性 和 灵活 性 。 

(SODR 

在 MMC 卡 基 础 上 研发 的 SD 卡 与 MMC 具有 一 定 的 兼容 性 ,但 SD 卡 的 容量 要 大 得 
多 , 且 读 写 速 度 也 比 MMC 卡 快 4 倍 。SD 卡 的 衍生 产品 有 Mini SD 卡 和 Micro SD 卡 ,2005 
年 推出 Micro SD 卡 只 有 指甲 般 大 小 ,智能 手机 上 使 用 的 扩展 内 存 卡 就 是 这 种 极 小 的 存 
储 卡 。 

(6) xD 卡 

xD 卡 不 仅 满 足 了 现 有 数码 相机 用 户 对 大 存储 容量 及 良好 兼容 性 的 需求 ,而 且 其 袖珍 的 
体积 也 为 生产 设计 更 精致 小 巧 的 数码 相机 打下 了 基础 。 在 读 写 兼容 性 上 ,xD 卡 不 仅 拥 有 
PC 卡 适 配器 和 USB 读 卡 器 ,非常 容易 与 个 人 计算 机 连接 ,而 且 小 巧 的 体积 还 让 它 可 以 插入 
CF 适配器 ,在 使 用 CF 卡 的 数码 相机 中 使 用 。 

(7) 微 便 盘 

微 便 盘 是 一 款 超 级 迷你 人 硬盘 机 产品 ,其 最 初 的 容量 为 340MB 和 512MB ,而 现在 的 产品 
容量 有 8GB、16GB 和 30GB 等 。 可 以 使 用 CF 卡 的 大 多 数 设 备 大 都 可 以 直接 使 用 微 硬盘 。 
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固态 便 盘 (Solid State Disk) 是 用 固态 电子 存储 心 片 阵 列 而 制 成 的 硬盘, 巾 控制 单元 和 
存储 单元 (Flash 芯片 或 DRAM 芯片 ) 组 成 。 目 前 ,固态 硬盘 主要 用 来 在 便携 式 计 算 机 中 代 
替 传 统 硬盘 。 虽 然 在 固态 硬盘 中 已 经 没有 可 以 旋转 的 盘 状 结构 ,但 是 依照 人 们 的 命名 习惯 ， 
仍然 将 其 称 为 "硬盘 ?。 固 态 硬 盘 的 接口 规范 和 和 定义、 功能 及 使 用 方法 与 普通 硬盘 的 相同 ,在 
产品 外 形 和 斥 寸 上 也 与 普通 硬盘 一 致 ,新 一 代 的 固态 硬盘 普 过 采用 SATA-2 接口 及 SATA- 
3 接口 。 

基于 闪存 (Flash 芯片 ) 的 固态 硬盘 是 固态 硬盘 的 主要 类 别 , 其 内 部 构造 十 分 简单 ,固态 
硬盘 内 主体 其 实 就 是 一 块 PCB 板 ,而 这 块 PCB 板 上 最 基本 的 配件 就 是 控制 芯片 、 缓 存 芯 
和 用 于 存储 数据 的 闪存 心 

固态 便 盘 的 特点 如 下 : 

JU 读 写 速度 快 。 采 用 闪存 作为 存储 介质 , 谈 取 速度 相对 机 械 人 硬盘 更 快 。 最 篆 见 的 
7200RPM 传统 硬盘 的 寻 道 时 间 一 般 为 12 一 14ms, 而 固态 硬盘 不 用 磁头 , 寻 道 时 间 几 乎 
为 0。 

GO 低 功 耗 、 无 噪音 .抗震 动 、 低 热量 。 基 于 闪存 的 固态 硬盘 在 工作 状态 下 能 耗 和 发 热量 
较 低 ;没有 机 械 马达 和 风扇 ,工作 时 噪音 值 为 0dB; 内 部 不 存在 任何 机 械 活 动 部 件 , 不 怕 碰 
撞 冲击 、 振 动 ;而 且 重 量 轻 , 工 作 温 度 范 围 大 。 

@ 寿命 限制 。 固 态 人 硬盘 的 闪存 具有 擦 写 次 数 限制 。 

目前 制约 固态 人 硬盘 普及 的 三 大 问题 是 :成 本 、 写 入 次 数 以 及 损坏 时 的 不 可 挽救 性 。 第 
一 ,固态 便 盘 的 位 价格 相对 传统 硬盘 要 高 出 数 倍 ;第 二 ,由 于 闪存 有 一 定 的 写 和 人 次数 限 制 , 寿 
命 结 束 后 会 无 法 写 入 , 变 成 只 读 状 态 ; 第 三 ,固态 便 盘 数据 损坏 后 是 难以 修复 的 ,现时 的 数据 
修复 技术 不 可 能 在 损坏 的 蕊 片 中 救 回 数据 ,相反 传统 人 硬盘 或 许 还 能 通过 一 些 数据 恢复 技术 
挽回 一 些 数据 。 


3. U 盘 


U 盘 全 称 是 USB 闪存 驱动 器 ,英文 名 “USB flash disk”。 它 是 一 种 基于 闪存 和 USB 接 
口 的 无 须 物理 驱动 硕 的 微型 大 容量 移动 存储 产品 ,通过 USB 接口 与 计算 机 连接 ,实现 即 插 
即 用 。 

U 盘 最 大 的 优点 是 : 小 巧 便于 携带 、 存 储 容量 大 、 价 格 便宜 、 性 能 可 徘 。U 盘 中 无 任何 
机 械 式 装置 ,抗震 性 能 极 强 。 男 外 ,还 具有 防潮 防磁 、 耐 高 .低温 等 特性 。U 盘 可 长 期 保存 
数据 , 擦 写 次 数 达 百 万 次 以 上 。 许 多 DU 盘 还 具有 写 保护 功能 ,可 以 防止 病毒 写 入 UU 盘 。 

U 盘 的 主要 目的 是 用 来 存储 数据 资料 ,但 目前 已 超越 此 目的 开发 出 了 更 多 的 功能 , 例 
如 加 密 UU 盘 、 启 动 U 盘 、 杀 毒 U 盘 、 测 温 U 盘 和 音乐 U 盘 等 。 

J 加密 U 盘 : 加 密 U 盘 分 为 两 类 ,一 类 采用 硬件 加 密 技 术 , 通 过 U 盘 的 主 控 芯片 进行 
加 密 , 安 全 级 别 高 ,不 容易 被 破解 ,但 成 本 较 高 ; 男 一 类 采用 软件 加 密 技 术 , 通 过 外 置 服务 端 
或 内 置 软件 操作 ,对 U 盘 文 件 进行 加 密 , 成 本 相对 较 低 。 

GO 启动 U 盘 : 启动 U 盘 也 分 为 两 类 ,一 类 专门 用 来 作 系 统 启动 用 的 功能 性 U 盘 , 当 计 
算 机 不 能 正常 开启 时 进入 系统 进行 相关 操作 ,功能 比较 单一 。 男 一 类 是 用 来 维护 计算 机 而 
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专门 制作 的 强大 的 功能 性 U 盘 , 除 了 可 以 启动 计算 机 外 还 可 以 有 磁盘 分 区 、 系 统 杀毒 、 系 统 
修复 ,文件 备份 、 密 码 修 改 等 功能 。 

@ 杀毒 U 盘 : 这 是 一 种 将 各 种 杀毒 软件 U 盘 版 栓 入 U 盘 中 ,使 杀毒 软件 使 用 更 方便 
快捷 安全、 操作 简单 ,与 USB 接口 相连 后 即 会 被 主机 识别 ,并 不 需要 烦琐 的 安装 。 

@ 测 温 U 盘 : 测 温 U 盘 可 分 为 两 类 ,一 类 是 在 计算 机 上 安装 了 一 个 软件 ,通过 UU 盘 中 
的 一 个 测试 温度 软件 ,感应 出 U 盘 所 获取 的 温度 。 男 一 类 是 直接 将 测试 温度 的 人 硬件 封装 在 
U 盘 内 ,并 直接 显示 在 U 盘 输出 LED 屏 上 。 

@ 音乐 U 盘 : 音乐 U 盘 既 有 U 盘 的 全 部 存储 功能 ,同时 还 具备 音乐 文件 的 播放 功能 。 
一 般 的 音乐 U 盘 外 观 和 普通 U 盘 并 无 异样 ,不 同 之 处 在 于 其 内 置 了 电池 ,并 多 出 一 个 插 孔 ， 
用 来 接 人 配备 的 耳机 , 搬 进 去 后 即 可 听取 MP3、WMA 等 常见 格式 音乐 ,支持 上 、 下 曲 播放 
选取 ,可 设置 随机 播放 功能 。 


8.7 键盘 输入 设备 


键盘 是 计算 机 系统 不 可 缺少 的 输入 设备 ,人 们 通过 键盘 上 的 按键 直接 回 计算 机 输入 各 
种 数据 .命令 及 指令 ,从 而 使 计算 机 完成 不 同 的 运算 及 控制 任务 。 


8.7.1 键 开 关 与 键盘 类 型 


键盘 上 的 每 个 按键 各 起 一 个 开关 的 作用 , 故 又 称 为 键 开关 。 键 开关 分 为 接触 式 和 非 接 
触 式 两 大 类 。 

接触 式 键 开 关中 有 一 对 触 点 ,最 常见 的 接触 式 键 开关 是 机 械 式 键 , 它 是 靠 按 键 的 机 械 动 
作 来 控制 开关 开局 的 。 当 键 帽 被 按 下 时 ,两 个 触 点 被 接 通 ; 当 键 帽 被 释放 时 ,弹簧 恢复 原来 
触 点 断 开 的 状态 。 这 种 键 开 关 结 构 人 简单 ,成 本 低 , 但 开关 通 断 会 产生 触 点 拌 动 ,而 且 使 用 寿 
命 较 短 。 

非 接 触 式 键 开 关 的 特点 是 : 开关 内 部 没有 机 械 接触 ,只 是 利用 按键 动作 改变 某 些 参数 
或 者 利用 某 些 效应 来 实现 电路 的 通 、 断 转换 。 非 接触 式 键 开 关 主 要 有 电容 式 键 和 和 霍 尔 键 两 
种 ,其 中 电容 式 键 是 比较 常用 的 。 这 种 键 开 关 无 机 械 磨 损 ,不 存在 触 点 拌 动 现象 ,性 能 稳定 ， 
寿命 长 ,已 成 为 当前 键盘 的 主流 。 

按照 键 码 的 识别 方法 ,键盘 可 分 为 两 大 类 型 : 编码 键盘 和 非 编 码 键盘 。 

编码 键盘 是 用 人 硬件 电路 来 识别 按键 代码 的 键盘 , 当 某 键 按 下 后 ,相应 电路 即 给 出 一 组 编 
码 信息 (如 ASCII 码 ) 送 主机 去 进行 识别 及 处 理 。 编 码 键盘 的 啊 应 速度 快 ,但 它 以 复杂 的 硬 
件 结构 为 代价 ,并且 其 硬件 的 复杂 程度 随 着 键 数 的 增加 而 增加 。 

非 编 码 键盘 是 用 较为 简单 的 硬件 和 专门 的 键盘 扫描 程序 来 识别 按键 的 位 置 , 即 当 按 某 
键 以 后 并 不 给 出 相应 的 ASCII 码 , 而 提供 与 按 下 键 相 对 应 的 中 间 人 代码, 然后 再 把 中 间 代 码 
转换 成 对 应 的 ASCII 码 。 非 编码 键盘 的 啊 应 速度 不 如 编码 键盘 快 , 但 是 它 通 过 软件 编程 可 
为 键盘 中 某 些 键 的 重新 定义 提供 更 大 的 灵活 性 ,因此 得 到 广泛 的 使 用 。 


8.7.2 键盘 扫描 
在 大 多 数 键盘 中 , 键 开 关 被 排列 成 M 行 XN 列 的 矩阵 结构 ,每 个 键 开 关 位 于 行 和 列 的 
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交叉 处 。 非 编码 键盘 常用 的 键盘 扫描 方法 有 逐 行 扫描 法 和 行列 扫描 法 。 
1. 逐 行 扫描 法 
图 8-11 是 采用 了 逐 行 扫描 识别 键 码 的 8X8 键盘 矩阵 ,8 位 输出 端口 和 8 位 输入 端口 都 在 


键盘 接口 电路 中 ， ed dn el hn nn ll lb 一 Xi;), 输 入 端口 的 


8 条 输入 线 接 键盘 矩阵 的 列 线 (Yo 一 Y;)。 通 过 执行 键盘 扫描 程序 对 键盘 矩阵 进行 扫描 ,以 
识别 被 按键 的 行 、 列 位 置 。 


9+SV 9+5V 0+5V 90+5V 0 +SV 


EE Bass- 
第 3 列 “| 第 7 列 


8-11 采用 逐 行 扫描 法 的 8X8 键盘 矩阵 


键盘 扫描 程序 处 理 的 步骤 如 下 : 

Q@ 查询 是 否 有 键 按 下 。 首 先 由 CPU 对 输出 端口 的 各 位 置 “0”, 即 使 各 行 全 部 接地 , 然 
后 CPU 再 从 输入 端口 谈 人 数据 。 奋 谈 入 的 数据 全 为 "1”, 表 示 无 键 按 下 ;只 要 谈 入 的 数据 
中 有 一 个 不 为 "1”, 表 示 有 键 按 下 。 接 着 要 查 出 按键 的 位 置 。 

@) 查询 已 按 下 键 的 位 置 。CPU 首先 使 X, 王 0,X 一 X 全 为 “1”, 读 入 Yu 一 Y) , 苦 全 为 

1”, 表 示 按 键 不 在 这 一 行 ; 接 着 使 Xi 王 0, 其 余 各 位 为 全 “1”, 读 和 人 Yo 一 Yi ，…… 直至 Yo 一 
Y7 不 全 为 "1 为止, 从 而 确定 了 当前 按 下 的 键 在 键盘 和 矩阵 中 的 位 置 。 

(3 按 行 号 和 列 号 求 键 的 位 置 码 。 得 到 的 行 号 和 列 号 表示 按 下 键 的 位 置 码 。 

对 于 接触 式 键 开关 ,为 避免 触 点 抖动 造成 的 干扰 ,通常 采用 软件 延 时 的 方法 来 等 候 信和 号 
稳定 。 具 体 的 做 法 是 : 在 检查 到 有 键 按 下 以 后 延 时 一 段 时 间 ( 约 20ms) ,再 检查 一 次 是 否 有 
键 按 下 。 知 这 一 次 检查 不 到 , 则 说 明 前 一 次 检查 结果 为 干扰 或 者 抖动 ;各 这 一 次 检查 到 有 键 
按 下 , 则 可 确认 这 是 一 次 有 效 的 按键 。 


2. 行列 扫描 法 


在 扫描 每 一 行 时 , 读 列 线 , 硅 读 得 的 结果 为 全 “1”, 说 明 没有 键 按 下 , 即 沿 未 扫描 到 闭合 
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键 ; 右 茶 一 列 为 低 电 平 ,说 明 有 键 按 下 ,而且 行 号 和 列 号 已 经 确定 。 然 后 用 同样 的 方法 ,依次 
回 列 线 扫描 输出 , 读 行 线 。 如 果 两 次 所 得 到 的 行 号 和 列 号 分 别 相同 , 则 键 码 确定 无 疑 , 即 得 
到 闭合 键 的 行列 扫描 码 。 


8.7.3 微型 计算 机 键盘 


从 按键 的 数量 上 看 ,微型 计算 机 的 键盘 有 83 键 (PC/XT)、84 键 (PC/AT)、101 和 102 
键 (386、486 机 ) 、104 键 (Pentium) 、105 键 ,108 键 、109 键 等 多 种 。 

键盘 通常 通过 设 在 主板 上 的 键盘 接口 连 到 主机 上 ,人 们 通过 键盘 输入 的 数据 是 在 主机 
的 BIOS 程序 的 控制 下 传送 到 主机 的 CPU 中 进行 处 理 的 。 图 8-12 为 PC/XT 键盘 与 接口 
框图 ,图 中 虚线 的 左 侧 部 分 是 PC/XT 键盘 , 右 侧 部 分 是 键盘 接口 ,位 于 微机 主板 上 。 


PCLK 


(GE 


8-12 PC/XT 键盘 与 接口 


1. 键盘 控制 电路 


PC 系列 键盘 一 般 由 键盘 矩阵 和 以 单片机 或 专用 控制 硕 为 核心 的 键盘 控制 电路 组 成 ， 
被 称 为 智能 键盘 。 单 片 机 通过 执行 固化 在 ROM 中 的 键盘 管理 和 扫描 程序 ,对 键盘 矩阵 进 
行 扫描 ,发 现 . 识别 按 下 键 的 位 置 ,形成 与 按键 位 置 对 应 的 扫描 码 ,并 以 串 行 的 方式 送 给 微机 
主板 上 的 键盘 接口 电路 , 供 系 统 使 用 。 

PC/XT 键盘 (83 键 ) 采 用 16 行 X8 列 矩 阵 结 构 , 由 8048 单片机 实现 闭合 键 检测 、 键 码 
识别 和 与 主机 通信 的 控制 。8048 通过 译 码 器 ,分 别 产 生 16 个 行 扫描 信号 和 8 个 列 扫描 信 
号 。 扫 描 方式 采用 行列 扫描 法 , 即 先 逐 列 为 “1” 地 进行 列 扫描 ,和 矩阵 检测 器 输出 送 8048 测试 
端 TT ,可 判断 是 否 有 行 线 输 出 *1”, 从 而 得 到 闭合 键 的 列 号 。 然 后 采用 同样 的 方法 , 逐 行 为 
“1” 地 进行 行 扫 描 , 得 到 闭合 键 的 行 号 。8048 将 列 号 和 行 号 拼 成 一 个 7 位 的 扫描 码 ( 列 号 为 
前 3 位 , 行 号 为 后 4 位 ) ,例如 第 4 列 第 7 行 键 被 按 下 , 则 得 到 闭合 键 的 扫描 码 为 47H。 

在 8048 中 有 一 个 20 字 节 的 缓冲 队列 ,能 暂 存 20 个 扫描 码 。 当 多 键 深 按 时 ,大 干 按键 
的 扫描 码 便 被 放 入 缓冲 队列 。 按 先进 先 出 的 原则 从 缓冲 区 取出 扫描 码 送 往 接口 ,以 免 高 速 
按键 时 主机 来 不 及 进行 中 断 响 应 和 处 理 。8048 的 键盘 扫描 程序 还 能 完成 去 拌 动 、 延 时 自动 
拍 发 等 复杂 功能 。 
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键盘 内 部 的 单片机 根据 按键 位 置身 主机 发 送 的 仅 是 该 按键 位 置 的 键 扫描 码 。 当 键 按 下 
时 ,输出 的 数据 称 为 接 通 扫描 码 ; 当 键 松 开 时 ,输出 的 数据 称 为 断 开 扫 描 码 。 

对 于 83 键 键盘 ,由 键盘 扫描 电路 得 到 的 接 通 扫描 码 与 键 号 ( 键 的 位 置 编号 ) 相 等 ,用 
1 个 字 节 表示 , 断 开 扫 描 码 也 用 1 个 字 节 表示 ,其 值 为 接 通 扫描 码 加 80H。 例 如 ,“A” 的 键 
号 为 30, 接 通 扫描 码 为 1EH ,上 断 开 扫描 码 为 9EH。 

对 于 84/101/102/104 扩展 键盘 ,由 于 键 位 置 发 生变 化 ,其 接 通 扫描 码 与 键 号 不 相等 。 
但 是 , 接 通 扫描 码 仍 用 1 个 字 节 表示 , 断 开 扫 摘 码 用 两 个 字 节 表示 ,其 值 为 接 通 扫描 码 前 加 
1 个 字 节 的 前 级 FOH。 仍 以 "A? 键 为 例 , 它 的 键 号 为 31, 接 通 扫 摘 码 为 1CH ,上 断 开 扫描 码 为 
FOH 1CH。 


2. 键盘 接口 电路 


键盘 接口 电路 一 般 在 微机 主板 上 ,通过 电缆 与 键盘 连接 , 串 行 地 接收 键盘 送 来 的 扫 摘 
码 , 或 者 问 键 盘 发 送 命令 ,要 求 键 盘 完 成 一 定 的 工作 (如 自 检 )。 其 功能 主要 有 : 

Q@ 串 行 接收 键盘 送 来 的 接 通 扫描 码 和 断 开 扫 描 码 ,转换 成 并 行 数 据 并 暂 存 。 

@@ 收 到 一 个 完整 的 扫描 码 后 ,立即 向 主机 发 中 断 请 求 。 

@ 主机 中 断 响应 后 读 取 扫 描 码 ,并 转换 成 相应 的 ASCII 码 存 人 键盘 缓冲 区 。 对 于 控制 
键 ,设置 相应 的 状态 。 

网 接收 主机 发 来 的 命令 ,传送 给 键盘 ,并 等 候 键 盘 的 啊 应 , 自 检 时 用 以 判断 键盘 的 正 
确 性 。 

对 于 83 键 键盘 ,键盘 接口 电路 主要 由 8255A-5 和 74LS322 移 位 寄存 器 构成 , 称 为 PC 
标准 键盘 接口 。 对 于 扩展 键盘 ,键盘 接口 电路 主要 由 单片机 8042/8742 构成 , 称 为 扩展 键盘 
接口 。 由 于 扩展 键盘 的 扫描 码 与 系统 扫描 码 不 一 致 ,因此 8042/8742 除了 完成 上 述 功能 以 
外 ,还 要 完成 由 键盘 扫描 码 到 系统 扫描 码 的 转换 。 所 谓 系统 扫描 码 就 是 与 相应 83 键 键 盘 中 
同 字 符 的 接 通 扫描 码 。 

从 键盘 送 来 的 串 行 扫 描 码 在 移 位 寄存 器 中 由 时 钟 控制 依次 右 移 ,组 装 成 并 行 扫 描 码 , 然 
后 向 主机 CPU 发 出 中 断 请 求 IRQ, 。 主 机 CPU 响应 键盘 中 断 请 求 后 ,执行 由 BIOS 提供 的 
键盘 中 断 处 理 程序 (09H 类 型 中 断 )。 该 程序 首先 以 并 行 方 式 从 接口 取出 扫描 码 , 接 着 对 收 
到 的 扫描 码 进 行 识别 , 判 断 按 下 的 键 是 字符 键 还 是 控制 键 ,由 中 断 服务 程序 通过 查 表 , 将 扫 
描 码 转换 为 相应 的 ASCII 码 或 扩充 码 后 送 入 键盘 缓冲 区 ,中断 处 理 完毕 返回 主 程序 。 当 系 
统 或 用 户 需要 键盘 输入 时 ,可 直接 在 主 程序 中 以 软 中 断 指令 (INT 16H) 的 形式 调用 BIOS 
的 键盘 1/O 程序 ,从 键盘 缓冲 区 中 取 走 所 需 的 字符 。 

在 微型 计算 机 中 ,所 有 字母 数字 等 由 键盘 输入 后 均 以 ASCII 码 的 形式 存放 在 键盘 组 
冲 区 ,在 存放 时 ,每 个 键 的 编码 占 两 个 字 节 ,其 中 高 字 节 仍 是 系统 扫描 码 , 低 字 节 是 由 中 断 服 
务 程序 转换 成 的 ASCII 码 。 男 外 ,还 有 一 些 键 没有 对 应 的 ASCII 码 , 如 命令 键 , 组 合 功 能 
键 , 对 于 这 些 键 则 用 扩充 码 表示 。 扩 充 码 存放 时 高 位 字 节 是 扩充 码 , 低 位 字 节 是 00H。 这 
就 是 说 ,BIOS 中 断 服务 程序 执行 时 首先 检查 输入 的 系统 扫描 码 是 否 可 以 转换 成 ASCII 码 。 
如 果 可 以 , 则 转换 成 ASCII 码 , 存 人 键盘 缓冲 区 ;如 果 不 可 以 , 则 转换 成 扩充 码 , 存 人 键盘 组 
冲 区 。 

键盘 缓冲 区 是 一 个 先进 先 出 的 循环 队列 ,其 容量 (16 个 字 ) 足 以 满足 操作 员 快 速 输入 键 
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符 的 需要 。 键 盘 缓 冲 区 是 键盘 中 断 程 序 (09H 类 型 中 断 ) 与 键盘 1/O 程序 (INT 16H) 之 间 
进行 数据 传递 的 媒介 体 , 进 队 列 即 由 BIOS 中 断 服务 程序 将 键盘 输入 的 系统 扫描 码 转 换 成 
ASCII 码 或 扩充 码 , 按 “先进 先 出 ”的 原则 输入 到 键盘 缓冲 区 中 ;出 队列 即 由 主机 执行 软件 中 
断 INT 16H, 按 同样 的 原则 读 取 键盘 缓冲 区 中 的 ASCII 码 或 扩充 码 予 以 处 理 或 执行 。 


8.8 其 他 输入 设备 


目前 ,计算 机 系统 常用 的 输入 设备 除 键盘 外 ,还 有 眼 标 .扫描 仪 . 光 笔 、 数 字 化 仪 等 。 键 
盘 输 入 的 是 字符 和 数字 信息 ,鼠标 主要 输入 矢量 信息 和 坐标 数据 ,而 扫描 仪 主 要 输入 图 形 、 
图 像 信 息 。 


8.8.1 鼠标 器 


鼠标 融 是 控制 显示 副 光 标 移动 的 输入 设备 ,由 于 它 能 在 屏 禹 上 实现 快速 精确 的 光标 害 
位 ,可 用 于 屏 磊 编辑 、 选 择 菜 单 和 屏 梨 作 图 ,鼠标 带 已 成 为 计算 机 系统 中 必 不 可 少 的 输入 
设备 。 

鼠标 硕 按 其 内 部 结构 的 不 同 可 分 为 机 械 式 、 光 机 式 和 光电 式 三 大 类 。 尽 管 结构 不 同 , 但 
从 控制 光标 移动 的 原理 上 讲 三 者 基本 相同 ,都 是 把 鼠标 耸 的 移动 距离 和 方 问 变 为 脉冲 信号 
送 给 计算 机 ,计算 机 再 把 脉冲 信号 转换 成 显示 融 光 标的 坐标 数据 ,从 而 达到 指示 位 置 的 
目的 。 


1. 机 械 式 鼠标 


机 械 鼠 标的 结构 最 为 简单 ,由 鼠标 撒 部 的 胶 质 小 球 珊 动 X 方 问 滚 轴 和 YY 方 问 滚 轴 ,在 
深 轴 的 末端 有 详 码 轮 , 译 码 轮 附 有 金属 导电 厂 与 电 刷 直接 接触 。 鼠 标的 移动 市 动 小 球 的 深 
动 , 青 通过 摩擦 作用 使 两 个 深 轴 市 动 译 码 轮 旋转 ,接触 译 码 轮 的 电 刷 随即 产生 与 二 维 空间 位 
移 相 关 的 脉冲 信号 。 目 前 ,纯粹 的 机 械 鼠 标 已 经 基本 消失 ,我 们 见 到 的 底部 带 小 球 的 鼠标 都 
是 光 机 式 鼠 标 。 


2. 光 机 式 鼠 标 


光 机 鼠标 顾名思义 就 是 一 种 光电 和 机 械 相 结合 的 鼠标 ,在 机 械 鼠 标的 基础 上 ,将 订 损 最 
历 害 的 接触 式 电 刷 和 译 码 轮 改 为 非 接触 式 的 LED 对 射 光 路 元 件 。 当 小 球 滚 动 时 ,X、Y 方 
加 的 滚 轴 市 动 码 盘 旋转 。 安 装 在 码 盘 两 侧 有 两 组 发 光 二 极 管 和 光敏 三 极 管 ,LED 发 出 的 光 
束 有 时 照射 到 光敏 三 极 管 上 ,有 时 则 被 阻 断 ,从 而 产生 了 两 组 相位 相差 90 的 脉冲 序列 。 脉 
冲 的 个 数 代表 鼠标 的 位 移 量 , 而 相位 表示 鼠标 运动 的 方向。 由 于 采用 的 是 非 接 触 部 件 ,使 磨 
损 率 下 降 , 从 而 提高 了 鼠标 的 寿命 ,也 能 在 一 定 范围 内 提高 鼠标 的 精度 。 


3. 光电 式 鼠 标 


光电 鼠标 内 部 有 一 个 发 光 二 极 管 , 通 过 其 发 出 的 光线 , 照 亮 光电 鼠标 帮 部 表面 ,然后 将 
反射 回来 的 一 部 分 光线 ,经 过 一 组 光学 透镜 ,传输 到 一 个 光 感 应 豆 件 内 成 像 。 这 样 , 当 光 电 
鼠标 移动 时 ,其 移动 轨迹 便 会 被 记录 为 一 组 高 速 提 摄 的 连贯 图 像 。 最 后 利用 光电 鼠标 内 部 
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的 一 块 专用 图 像 分 析 芯 片 对 移动 轨迹 上 摄取 的 一 系列 图 像 进行 分 析 处 理 , 通 过 对 这 些 图 像 
上 特征 点 位 置 的 变化 进行 分 析 , 来 判断 鼠标 的 移动 方向 和 移动 距离 ,从 而 完成 光标 的 定位 。 
除 前 述 3 类 传统 鼠标 外 ,现在 还 出 现 了 激光 鼠标 。 
激光 鼠标 其 实 也 是 光电 鼠标 ,只 不 过 是 用 激光 代替 了 普通 的 LED 光 。 相 对 于 传统 的 鼠 ” 
标 来 说 ,激光 鼠标 是 将 鼠标 本 身 的 激光 照射 在 物体 表面 ,同时 物体 表面 的 激光 反射 回 激光 鼠 
标的 传感器 之 内 。 由 于 激光 能 对 图 像 产 生 更 大 的 反差 ,所 以 激光 鼠标 相对 于 传统 鼠标 来 讲 ， 
灵敏 度 更 佳 ,定位 更 加 准确 ,扫描 速度 更 快 。 
鼠标 与 计算 机 的 联接 方式 分 为 有 线 和 无 线 两 种 ,有 线 鼠 标 按 接口 类 型 可 分 为 串 行 鼠标 、 
PS/2 鼠标 .USB 鼠标 几 种 。 串 行 鼠 标 是 通过 串 行 口 与 计算 机 相连 ,有 9 针 接 口 .25 针 接 口 
两 种 。PS/2 鼠标 通过 一 个 6 针 微 型 DIN 接口 与 计算 机 相连 , 它 与 键盘 的 接口 非常 相似 ,使 
用 时 应 注意 区 分 。USB 鼠标 通过 一 个 USB 接口 ,直接 插 在 计算 机 的 USB 口上 。 
无 线 鼠 标 主 要 有 以 下 几 种 : 
@D 27MHz 的 无 线 鼠 标 ,其 发 射 距离 在 2m 左右 ,而 且 信 和 号 不 稳定 ,相对 比较 低档 。 
@ 2.4GHz 的 无 线 鼠 标 , 其 接受 信号 的 距离 在 7 一 15m, 信 号 比较 稳定 ,目前 市 场 主要 
是 这 一 种 。 
G) 蓝牙 鼠标 ,其 发 射频 率 和 2. 4GHz 一 样 ,接受 信号 的 距离 也 一 样 。 蓝 牙 有 一 个 最 大 
的 特点 就 是 通用 性 ,如果 计算 机 带 蓝 牙 功 能 ,那么 不 需要 蓝牙 适配器 就 可 以 直接 连接 ,可 以 
节约 一 个 USB 插口 。 
鼠标 按键 数 可 以 分 为 双 键 .三 键 和 多 键 鼠 标 。 三 键 鼠 标的 中 键 在 某 些 特殊 程序 中 往往 
能 起 到 事半功倍 的 作用 ;多 键 鼠 标 是 新 一 代 多 功能 鼠标 ,如 有 的 鼠标 上 带 有 滚轮 ,使 得 上 下 
翻 页 变 得 极其 方便 。 有 的 新 型 鼠标 上 除了 有 滚轮 ,还 增加 了 拇指 键 等 快捷 按键 ,进一步 简化 
了 操作 程序 。 


8.8.2 其 他 定位 设备 


随 独 便携 式 计 算 机 的 出 现 , 鼠 标 硕 已 不 能 适应 新 的 要 求 , 因 此 又 出 现 了 一 些 新 的 定位 
设备 。 


1. 轨迹 球 


轨迹 球 的 结构 趴 像 一 个 倒置 的 鼠标 ,好 像 在 小 圆 盘 上 久 搁 一 颗 圆 球 。 轨 迹 球 的 功能 与 
鼠标 相似 , 朝 着 指定 的 方向 转动 小 球 ,光标 就 在 屏幕 上 朝 着 相应 的 方向 移动 。 轨 迹 球 可 以 独 
立 使 用 ,也 利 稼 租 在 键盘 上 ,其 优点 是 不 像 鼠 标 那样 必须 有 可 供 滑动 的 较 大 的 空间 。 


2. 跟踪 点 


跟踪 点 是 一 个 压 敏 淡 置 ,只 有 铅笔 上 的 橡皮 大 小 ,所 以 可 刍 在 按键 之 间 , 用 手指 轻 轻 推 
它 , 光 标 就 朝 看 指点 的 方 回 移动 。 


3. 触摸 板 


触摸 板 是 一 种 方便 的 输入 设备 , 它 的 表面 对 压力 和 运动 敏感 , 当 用 手指 轻 轻 在 触摸 板 滑 
动 时 ,屏幕 上 的 光标 就 同步 运动 。 有 的 触摸 板 周 围 设 有 按钮 ,其 作用 与 鼠标 的 按钮 相同 , 玫 
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一 些 触 摸 板 , 则 是 通过 轻 项 触 措 板 表 面 完 成 与 点 击 鼠 标 相 同 的 操作 。 
8.8.3 扫描 仪 


扫描 仪 是 一 种 光 、 机 、 电 一 体 化 的 高 科技 产品 , 它 是 将 各 种 形式 的 图 像 信 息 输 入 计算 机 
的 重要 工具 ,是 继 键盘 和 鼠标 之 后 的 第 三 代 计 算 机 输入 设备 ,也 是 功能 极 强 的 一 种 输入 设 
备 。 从 最 直接 的 图 片 、 照 片 .胶片 到 各 类 图 纸 图 形 以 及 文稿 资料 都 可 以 用 扫描 仪 输入 到 计算 
机 中 ,进而 实现 对 这 些 图 像 形式 信息 的 处 理 、 管 理 \ 使 用 、 存 储 、 输 出 等 。 配合 文字 识别 软件 ， 
还 可 以 将 扫描 的 文稿 转换 成 计算 机 的 文本 形式 。 


1. 扫描 仪 的 组 成 部 分 及 工作 原理 


日 然 界 每 一 种 物体 都 会 吸收 特定 的 光波 ,而 没有 吸收 的 光波 就 会 被 反射 出 去 。 扫 描 仪 
就 是 利用 这 种 特性 来 完成 对 稿件 的 读 取 的 。 扫 描 仪 在 工作 时 会 发 出 强 光 照射 在 稿件 上 , 没 
有 被 吸收 的 光线 将 被 反射 到 光学 感应 需 上 。 光 学 感应 需 接 收 到 这 些 信号 后 ,再 将 这 些 信和 号 
传送 到 数 模 转换 器 , 数 模 转 换 器 再 将 其 转换 成 计算 机 能 够 读 取 的 信号 ,然后 通过 驱动 程序 转 
换 成 显示 帮 上 能 看 到 的 正确 图 像 。 欲 扫描 的 稿件 通常 可 以 分 为 反射 稿 和 透射 稿 。 反 射 稿 泛 
指 一 般 的 不 透明 文件 ,例如 报纸 、 杂 志 等 。 透 射 稿 包括 幻灯 刻 ( 正 片 ) 或 底 刻 (人 锋 刻 )。 如 果 经 
党 需 要 扫描 透射 稿 , 那 就 必须 选择 具备 光 单 (光板 ) 功 能 的 扫 摘 仪 。 

扫 摘 仪 的 光学 读 取 装置 相当 于 人 的 眼球 ,其 重要 性 不 言 而 喻 。 目 前 ,扫描 仪 所 使 用 的 光 
学 读 取 装置 有 CCD 和 CIS 两 种 。 

(1) CCD(Charge Coupled Device) 

CCD 的 中 文 名 称 为 电荷 耦合 装置 。 它 采用 电 和 荷 耦 合 的 微型 半导体 感光 忆 片 作为 扫 摘 
仪 的 核心 。CCD 与 日 淄 使 用 的 半导体 集成 电路 相似 ,在 一 片 硅 单 晶 上 集成 了 几 千 到 几 万 个 
光电 三 极 管 ,这 些 光电 三 极 管 分 为 3 列 , 分 别 用 红 、 绿 、 蓝 色 的 滤 色 镜 单 住 ,从 而 实现 彩色 扫 
摘 。 光 电 三 极 管 在 受到 光线 照射 时 可 以 产生 电流 ,经 放大 后 输出 。 采 用 CCD 的 扫 摘 仪 技术 
经 过 多 年 的 发 展 已 经 相当 成 熟 , 是 目前 市 场 上 主流 扫描 仪 主 要 采用 的 感光 元 件 。CCD 的 优 
势 主 要 在 于 : 扫描 的 图 像 质 量 近年 来 提高 很 大 ;具有 一 定 的 景深 ,能 够 扫 摘 凹凸 不 平 的 物 
体 ; 温 度 系数 比较 低 , 对 周围 环境 温度 的 变化 可 以 忽略 不 计 。CcCD 的 缺陷 主要 有 : 由 于 数 
千 个 光电 三 极 管 的 距离 很 近 ( 微 米 级 ) ,在 各 光电 三 极 管 之 间 存 在 着 明显 的 漏电 现象 ,各 感光 
单元 的 信号 产生 干扰 ,降低 了 扫描 仪 的 实际 清晰 度 ; 由 于 采用 了 反射 镜 、 透 镜 , 会 产生 图 像 色 
彩 偏差 和 像 差 ,需要 通过 软件 进行 校正 ;由 于 CCD 需要 一 套 精密 的 光学 系统 , 故 扫描 仪 体积 
不 可 能 做 得 很 小 。 

(2) CIS(Contact Image Sensor) 

CIS 的 中 文 名 称 为 接触 式 图 像 感应 装置 。 它 采用 一 种 触 点 式 图 像 感 光 元 件 ( 光 敏 传 感 
器 ) 来 进行 感光 ,在 扫描 平台 下 1 一 2mm 处 ,300 一 600 个 红 . 蓝 、 绿 三 色 LED( 发 光 二 极 管 ) 传 
感 器 紧密 排列 在 一 起 产生 白色 光源 ,取代 了 CCD 扫描 仪 中 的 CCD 了 阵列、 透镜、 荧光 管 和 冷 
阴极 射线 管 等 复杂 结构 ,把 CCD 扫描 仪 的 光 、 机 、 电 一 体 变 为 CIS 扫描 仪 的 机 、 电 一 体 。 但 
CIS 技术 也 有 不 足 之 处 : CIS 固有 的 感光 特性 决定 了 这 种 扫描 仪 需要 一 次 扫描 、 三 次 曝光 ， 
所 以 扫描 速度 比较 慢 ; 由 于 CIS 没有 景深 的 概念 ,原稿 必须 与 感光 元 件 徘 得 很 近 才 行 , 这 样 
无 法 进行 实物 扫描 ;而 且 目 前 CIS 感光 元 件 的 性 能 决定 了 CIS 扫描 仪 分 辨 率 不 高 ,加 上 CIS 
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光源 的 均匀 性 不 够 好 ,使 得 CIS 扫描 仪 的 扫描 图 像 质 量 和 色彩 真实 度 不 是 太 好 ,其 至 比 不 
上 一 些 低 价位 的 CCD 扫描 仪 。 但 是 ,这 类 扫描 仪 具有 体积 小 .重量 轻 、 需 件 少 和 抗震 性 较 高 
的 优点 ,而 且 生 产 成 本 很 低 。 


2. 扫描 仪 的 主要 性 能 指标 


(1) 分 辨 率 

分 辨 率 通常 是 指 图 像 每 英寸 中 有 和 多少 个 像素 (Pixel)。 分 辨 率 对 图 像 的 质量 有 很 大 的 
影响 ,通常 分 辩 率 越 高 ,扫描 输入 的 时 间 就 越 长 。 扫 描 仪 的 分 辨 率 又 可 细 分 为 光学 分 辨 率 和 
最 大 分 辩 率 两 种 。 

Q 光学 分 辨 率 。 光 学 分 辩 率 是 扫描 仪 最 重要 的 性 能 指标 之 一 , 它 直 接 决 定 了 扫描 仪 扫 
描 图 像 的 清晰 程度 。 扫 描 仪 的 光学 分 辨 率 用 每 英寸 长 度 上 的 点 数 , 即 DPI 来 表示 。 通 篆 ， 
低档 扫描 仪 的 光学 分 辨 率 为 300 X600DPI, 中 高 档 扫 描 仪 的 光学 分 辩 率 为 600 X 1200DPI。 

光学 分 辩 率 指 的 是 扫描 仪 实 际 工作 时 的 分 辨 能 力 , 也 就 是 在 每 英寸 上 它 所 能 扫描 的 光 
学 点 数 。 通 常 这 个 数值 是 不 变 的 ,因为 它 由 光学 感应 元 件 的 性 能 决定 。 

GO 最 大 分 辨 率 。 最 大 分 辨 率 又 称 软件 分 辨 率 ,通常 是 指 利 用 软件 插值 补 点 的 技术 模拟 
出 来 的 分 辨 率 。 光 学 分 辨 率 为 300X600DPI 的 扫 摘 仪 一 般 最 大 分 辩 率 可 达 4800DPI, 而 
600 X1200DPI 的 扫描 仪 则 更 高 达 9600DPI。 这 实际 上 是 通过 软件 在 真实 的 像素 点 之 间 插 
入 经 过 计算 得 出 的 额外 像素 ,从 而 获得 的 插值 分 状 率 。 插 值 分 状 率 对 于 图 像 精度 的 提高 并 
无 好 处 ,事实 上 只 要 软件 支持 ,而 用 户 的 机 器 又 强劲 ,这 种 分 辨 率 完全 可 以 做 到 无 限 大 。 

(2) 色彩 深度 值 

色彩 深度 值 又 称 为 色 阶 或 色彩 位 数 , 指 的 是 扫描 仪 色彩 识别 能 力 的 大 小 。 扫 描 仪 是 利 
用 R( 红 )、G( 绿 )、B( 蓝 ) 三 原色 来 读 取 数据 的 ,如 果 每 个 原色 以 8 位 数据 来 表示 ,总 共 就 有 
24 位 , 即 扫描 仪 有 24 位 色 阶 ;如 果 每 个 原色 以 12 位 数据 来 表示 ,总 共 就 有 36 位 , 即 扫描 仪 
有 36 位 色 阶 , 它 所 能 表现 出 的 色彩 将 会 有 680 亿 (228) 色 以 上 。 较 高 的 色彩 深度 位 数 可 以 
保证 扫描 仪 反映 的 图 像 色 彩 与 实物 的 真实 色彩 尽 可 能 的 一 致 ,而 且 图 像 色 彩 会 更 加 丰富 。 
一 般 光 学 分 辨 率 为 300 X600DPI 的 扫描 仪 其 色彩 深度 为 24 位 、30 位 ,而 600 X1200DPI 的 


为 36 位 ,最 高 的 为 48 位 。 
(3) 灰 度 值 
灰 度 值 是 指 进行 灰 度 扫描 时 对 图 像 由 纯 黑 到 纯 白 整个 色彩 区 域 进 行 划 分 的 级 数 ,又 称 


为 灰 度 动态 范围 。 灰 度 值 越 高 ,扫描 仪 能 够 表现 的 暗部 层次 就 越 细 。 灰 度 值 的 大 小 对 于 扫 
描 仪 正 负片 通常 会 有 较 大 的 影响 。 编 辑 图 像 时 一 般 都 使 用 到 8 位 , 即 256 级 ,而 主流 扫描 仪 
通常 为 10 位 ,最 高 可 达 12 位 。 


8.9 打印 输出 设备 
打印 机 是 计算 机 系统 的 主要 输出 设备 之 一 ,打印 机 的 功能 是 将 计算 机 的 处 理 结果 以 字 


符 或 图 形 的 形式 印刷 到 纸 上 ,转换 为 书面 信息 ,便于 人 们 阅读 和 保存 。 由 于 打印 输出 结果 能 
够 永久 性 保留 , 故 称 为 硬 拷贝 输出 设备 。 


oo 
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8.9.1 打印 机 概述 


按照 打印 的 工作 原理 不 同 , 打 印 机 分 为 击 打 式 和 非 击 打 式 打印 机 两 大 类 。 击 打 式 打印 
机 是 利用 机 械 作 用 使 印字 机 构 与 色 市 和 纸 相 撞击 而 打印 字符 的 , 它 的 工作 速度 不 可 能 很 高 ， 
而 且 不 可 避免 地 要 产生 工作 噪声 ,但 是 设备 成 本 低 , 针 式 打 印 机 就 是 使 用 最 广泛 的 击 打 式 打 
印 机 。 非 击 打 式 打印 机 是 采用 电磁 、 光 \ 顺 墨 等 物理 或 化 学 方法 印刷 出 文字 和 图 形 的 ,由 于 
印字 过 程 没 有 击 打 动作 ,因此 印字 速度 快 、 噪 声 低 ,但 一 般 不 能 复制 多 份 , 目 前 主要 有 喷 墨 打 
印 机 、 激 光 打 印 机 等 。 

打印 机 按照 输出 工作 方式 可 分 为 串 式 打印 机 、 行 式 打印 机 和 页 式 打 印 机 3 种 。 串 式 打 
印 机 是 单字 锤 的 逐 字 打印 ,在 打印 一 行 字符 时 ,不 论 所 打印 的 字符 是 相同 或 不 同 的 , 均 按 顺 
序 沿 字 行 方 问 依次 逐个 字符 打印 ,因此 打印 速度 较 慢 ,一般 用 字 每 秒 (CPS) 来 衡量 其 打印 速 
度 。 行 式 打印 机 是 多 字 锤 的 逐 行 打印 ,一 次 能 同时 打印 一 行 ( 多 个 字符 ) ,打印 速度 较 快 ,和 常 
用 行 每 分 (LPM) 来 衡量 其 速度 。 页 式 打 印 机 一 次 可 以 输出 一 页 ,打印 速度 最 快 ,一 般 用 页 
每 分 (PPM) 来 衡量 其 速度 。 

打印 机 按 印字 机 构 不 同 , 可 分 为 固定 字模 (活字 ) 式 打印 和 点 阵 式 打 印 两 种 。 固 定 字 模 
式 打 印 机 是 将 各 种 字符 塑 压 或 刻 制 在 印字 机 构 的 表面 上 ,印字 机 构 如 同 印 章 一 样 ,可 将 其 上 
的 字符 在 打印 纸 上 印 出 ;而 点 阵 式 打印 机 则 信 助 于 硅 干 点 阵 来 构成 字符 。 固 定 字 模式 打印 
的 字迹 清晰 ,但 字模 数量 有 限 , 组 字 不 灵活 ,不 能 打印 汉字 和 图 形 , 所 以 基本 上 已 被 淘汰 。 扣 
阵 式 打印 机 以 点 阵 图 拼 出 所 需 字 形 , 不 需 固定 字模 , 它 组 字 非 党 灵活 ,可 打印 各 种 字符 (包括 
汉字 ) 和 图 形 图像 等 。 现 在 人 们 普 忆 有 一 种 误解 ,只 把 针 式 打印 机 看 作 点 阵 打 印 机 ,这 是 不 
全 面 的 。 事 实 上 , 非 击 打 式 打印 机 输出 的 字符 和 图 形 也 是 由 点 阵 构 成 的 。 

打印 机 通常 有 两 种 工作 模式 , 即 文本 模式 (字符 模式 ) 和 图 形 模式 。 


1. 文本 模式 


在 这 种 方式 中 ,主机 向 打印 机 输出 字符 代码 (ASCII 码 ) 或 汉字 代码 (国标 码 ) ,打印 机 则 
依据 代码 从 位 于 打印 机 上 的 字符 库 或 汉字 库 中 取出 点 阵 数据 ,在 纸 上 “ 打 ”出 相应 字符 或 汉 
字 。 与 图 形 模 式 相 比 ,文本 模式 所 需 传 送 的 数据 量 少 ,占用 主机 CPU 的 时 间 少 ,因而 效率 
较 高 ,但 所 能 打印 的 字符 或 汉字 的 数量 受到 字库 的 限制 。 


2. 图 形 模式 


在 图 形 模 式 中 ,主机 向 打印 机 直接 输出 点 阵 图 形 数 据 , 有 一 个 “1” 就 “ 打 ” 一 个 点 。 在 这 
种 模式 下 ,CPU 能 灵活 控制 打印 机 输出 任意 图 形 , 从 而 可 打印 出 字符 、 汉 字 、 图 形 、 图 像 等 。 
但 是 ,图 形 模 式 所 需 传 送 的 数据 量 大 ,占用 主机 大 量 的 时 间 。 例 如 ,打印 一 个 24X24 点 阵 的 
汉字 ,传送 字符 点 阵 图 形 的 数据 量 (72 个 字 节 ) 远 大 于 传送 字符 代码 时 的 数据 量 (2 个 字 节 ) 。 


8.9.2 打印 机 的 主要 性 能 指标 


有 关 打 印 机 的 性 能 指标 主要 有 : 分 辩 率 .打印 速度 .打印 幅面 、 接 口 方式 和 缓冲 区 的 大 
小 等 。 
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1. 分 辨 率 


打印 机 的 打印 质量 是 指 打印 出 的 字符 的 清晰 度 和 美观 程度 ,用 打印 分 辨 率 表 示 ,单位 为 
每 英寸 打印 多 少 个 点 (DPI) 。 大 多 数 打 印 机 的 分 辩 率 在 垂直 和 水 平方 向 上 是 相同 的 ,目前 
激光 打印 机 的 分 辩 率 为 600DPI, 甚 至 可 达 1200DPI。 至 于 精密 照排 机 ,低档 的 在 700 一 
2000DPI ,高 档 的 则 可 达 2000 一 3000DPI。 


2. 打印 速度 和 打印 幅面 


不 同类 型 的 打印 机 具有 不 同 的 打印 速度 ,每 种 类 型 又 有 高 、 中 低速 之 分 。 
打印 机 的 打印 幅面 有 许多 种 ,一般 家 庭 用 户 使 用 A4 幅面 的 就 可 以 了 。 


3. 接口 方式 
打印 机 的 接口 可 以 是 标准 配置 并 行 接口 ,也 可 以 是 USB 接口 。 
4. 缓冲 区 


最 简单 的 缓冲 区 只 能 存放 一 行 打印 信息 , 当 这 一 行 信息 打印 完 后 , 即 清除 掉 缓 冲 区 的 信 
上 ,并 告诉 主机 "缓冲 区 空 ”, 主 机 将 再 发 送 新 的 信息 给 打印 机 ,如 此 反复 ,直到 所 有 信息 打印 
完毕 为 止 。 在 CPU 不 断 升级 的 情况 下 ,为 了 解决 计算 机 和 打印 机 速度 的 差异 ,必须 扩大 打 
印 机 的 缓冲 区 。 缓 冲 区 越 大 ,一 次 输入 数据 就 越 多 ,打印 机 处 理 打印 所 需 的 时 间 就 越 长 , 因 
此 ,与 主机 的 通信 次 数 就 可 以 减少 ,使 主机 的 效率 提高 。 


8.9.3 针 式 打印 机 工作 原理 


针 式 打印 机 在 打印 机 历史 上 曾经 占有 重要 的 地 位 ,其 价格 便宜 ,耐用 ,可 以 打印 多 层 纸 ， 
但 它 较 低 的 打印 质量 和 打印 速度 以 及 很 大 的 工作 噪声 也 使 它 无 法 适应 高 质量 高 速度 的 打 
印 需要 ,所 以 在 次 通 家 庭 及 办 公 应 用 中 逐渐 被 喷 墨 和 激光 打印 机 所 取代 ,只 在 需要 使 用 复写 
打印 的 场合 中 使 用 。 

针 式 打印 机 是 由 奋 干 根 打 印 针 印 出 痉 X2 个 点 阵 组 成 的 字符 或 汉字 图形。 这 里 m 表 
示 打 印 的 列 数 ,” 表 示 打 印 的 行 数 。 点 阵 越 密 , 印 字 的 质量 就 越 高 。 需 要 注意 的 是 ,字符 由 
mXn 个 点 阵 组 成 ,并 不 意味 着 打印 头 就 装 有 mr Xn 根 打 印 针 。 串 式 针 打 的 打印 涉 上 一 般 只 
装 有 一 列 妈 根 打 印 针 ( 也 有 的 分 为 两 列 ) , 通 稼 所 讲 的 9 针 .24 针 打印 机 指 的 就 是 打印 头 上 
打印 针 的 数目 。 打 印 头 是 打印 机 的 关键 部 件 , 打 印 机 的 打印 速度 .打印 质量 和 可 犊 性 在 很 大 
程度 上 取决 于 打印 头 的 功能 和 质量 。 

在 9 针 打 印 机 中 ,将 9 根 打 印 针 排 成 纵 回 一 列 , 每 次 打印 一 列 , 印 完 一 列 后 打印 头 油水 
平方 向 向 右 移动 一 步 ,mm 步 之 后 ,形成 一 个 mXn 点 阵 的 字形 。 在 24 针 打 印 机 中 ,一般 交 错 
排 成 两 列 ,每 列 12 根 针 ,分 别称 为 奇数 号 针 和 偶数 号 针 。 打 印 时 ,打印 头 从 左 到 右 打 印 ,一 
列 的 24 个 点 是 分 两 次 打印 出 来 的 。 由 于 点 的 纵向 间距 非常 小 ,甚至 能 相互 覆盖 一 部 分 ,所 
形成 的 图 形 轮廓 连贯 光滑 ,印字 质量 较 9 针 打 印 机 高 。 

打印 头 装 在 一 个 小 车 ( 称 为 字 车 ) 上 ,由 步 进 电机 驱动 ,可 进行 水 平移 动 与 精确 定位 。 打 
印 头 里 的 钢 针 在 驱动 电路 的 控制 下 ,打击 色 融 和 纸 , 从 而 形成 一 行 字符 。 在 打印 一 行 字符 的 
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过 程 中 ,打印 纸 不 动 。 在 打印 完 一 行 后 , 输 纸 机 构 带 动 打印 纸 向 前 推进 一 行 , 而 色 带 传动 机 
构 也 将 色 带 转动 一 定 尺 寸 , 使 打击 次 数 均匀 地 分 布 在 整 盘 色 带 上 。 针 式 打印 机 可 以 通过 调 
整 打印 头 与 纸张 的 间距 来 适应 打印 纸 的 不 同 厚度 ,而且 可 以 改变 打印 针 的 力度 以 调节 打印 
2 的 清晰 度 。 

针 式 打印 机 有 单 向 打印 和 双向 打印 两 种 。 兰 一行 字 符 打印 完 , 在 输 纸 的 同时 ,打印 头 左 
移 返回 到 起 始 位 置 ( 回 车 ) ,重新 由 左 向 右 打 印 ,这 就 称 为 单 问 打印 。 而 双向 打印 指 的 是 和 月 左 
向 右 一 行 字符 打印 完毕 后 ,打印 头 无 须 回 车 ,在 输 纸 的 同时 ,打印 头 再 从 右 向 左 打印 下 一 行 ， 
做 反 向 打印 。 由 于 省 去 了 空 回 车 时 间 ,所 以 双向 打印 的 打印 速度 较 单 向 打印 大 大 提高 。 

针 式 打印 机 控制 电路 如 图 8-13 所 示 。 主 机 要 输出 打印 信息 时 ,首先 要 检查 打印 机 所 处 
的 状态 。 当 打印 机 空闲 时 ,允许 主机 发 送 字 符 。 打 印 机 开始 接收 从 主机 送 来 的 字符 代码 
(ASCII 码 ), 先 判断 它们 是 可 打印 的 字符 还 是 只 执行 某 种 控制 操作 的 控制 字符 (如 “ 回 车 ” 
“换行 ”等 )。 如 果 是 可 打印 的 字符 ,就 将 其 代码 送 入 打印 行 缓冲 区 (RAM) 中 ,接口 电路 产生 
回答 信息 ,通知 主机 发 送 下 一 个 字符 。 如 此 重复 ,把 要 打印 的 一 行 字符 的 代码 都 存 人 数据 组 
冲 区 。 当 缓冲 区 接收 满 一 行 打印 的 字符 后 ,停止 接收 , 转 和 人 打印 。 


打印 列 点 阵 
= 至 
这 通信 号 一 0 了 | 字符 库 上 和 打 
回答 信和 号 (RAM) 一 一 (ROM) HO—~ ee 印 
全 一 一 | 器 头 
器 
字符 
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打印 时 序 控制 好 辑 | 和 


图 8-13 针 式 打印 机 控制 电路 
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打印 机 的 字符 库 中 存放 着 所 有 字符 的 列 点 阵 码 。 打 印 时 ,首先 形成 打印 字符 的 首 列 点 
阵 的 地 址 ,然后 按 顺 序 在 字符 库 中 一 列 一 列 地 找 出 字符 的 点 阵 , 送 往 打 印 头 控制 驱动 电路 ， 
激励 打印 头 出 针 打印 。 一 个 字符 打印 完 , 字 车 移动 几 列 ,再 继续 打印 下 一 个 字符 。 一 行 字 符 
打印 完 后 ,请 求 主机 送 来 第 二 行 打印 字符 代 码 , 同 时 输 纸 机 构 使 打印 纸 移动 一 个 行距 。 

一 般 针 式 打 印 机 内 部 只 市 西 文字 符 库 , 它 只 能 文 持 文本 的 打印 。 这 种 打印 机 奢 想 打印 
中 文 ,应 使 打印 机 处 于 图 形 模式 。 

针 式 打印 机 多 为 单 色 打印 机 ,现在 也 出 现 了 彩色 针 式 打印 机 。 针 式 彩 色 打 印 机 的 结构 
与 单 色 打印 机 相同 ,只 是 增加 了 色彩 功能 控制 。 彩 色 打 印 机 利用 了 三 基色 混 色 原理 ,使 用 的 
色 带 上 除了 有 一 条 黑色 带 外 ,还 有 红 、 蓝 、 黄 色 3 条 色 带 ,其 他 的 颜色 用 红 、 蓝 、 黄 三 色 混 合 多 
次 打印 组 合 而 成 。 

彩色 打印 机 的 字 车 上 所 附 的 色 市 不 仅 能 够 在 水 平方 向 上 横 加 往复 运动 ,而 且 能 够 上 下 
移动 ,这 样 就 可 以 用 一 个 打印 头 撞击 不 同 颜色 的 色 市 进行 彩色 打印 。 为 了 实现 多 种 彩色 的 
打印 ,彩色 打印 机 的 打印 控制 电路 还 增加 了 色 市 选择 电路 及 其 他 附属 电路 。 彩 色 打 印 机 打 
印 时 还 是 像 单 色 打 印 机 那样 ,对 于 每 种 颜色 的 色 带 都 是 按 从 左 到 右 的 顺序 击 打 , 不 同 的 是 它 
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要 选择 相应 的 色 带 。 如 果 打 印 的 是 色 带 上 的 三 基色 , 则 直接 选择 相应 的 色 带 打印 即 可 ;如 果 
打印 的 不 是 色 带 上 的 三 基色 , 则 需要 利用 三 基色 进行 配色 , 即 在 同一 点 上 选择 不 同 的 色 带 击 
打 , 混 合成 各 种 颜色 。 


8.9.4 叶 墨 打印 机 工作 原理 


喷 墨 式 打 印 机 也 属于 点 阵 式 打印 的 一 种 , 它 的 印字 原理 是 使 墨水 在 压力 的 作用 下 ,从 孔 
径 或 狭 缝 斥 才 很 小 的 喷 踪 喷 出 ,成 为 飞行 速度 很 高 的 墨 滴 ,根据 字 符 点 阵 的 需要 ,对 墨 滴 进 
行 控制 ,使 其 在 记录 纸 上 形 成 文字 或 图 形 。 喷 墨 打印 机 的 喷 墨 方式 有 两 种 : 连续 式 和 随机 
式 。 早 期 的 喷 墨 打印 机 以 及 当前 大 幅面 的 喷 墨 打印 机 采用 连续 式 喷 墨 技 术 ,普通 喷 墨 打印 
机 多 采用 随机 式 喷 墨 技术 。 


1. 连续 式 喷 墨 技术 


连续 式 是 指 连 续 不 断 地 喷射 墨水 ,首先 给 墨水 加 压 , 使 墨水 流通 过 喷嘴 连续 喷射 而 粒子 
化 。 因 为 墨水 市 有 正 离子 , 当 粒 子 化 的 墨水 穿 过 高 压 电场 时 ,就 发 生 偶 转 , 改 可 用 高 压 电 场 
控制 印字 。 

当 融 有 正 离子 的 墨水 由 喷 踪 喷 出 后 ,墨水 束 粒 子 化 为 小 水 滴 , 穿 进 偶 转 电极 , 右 想 印字 ， 
则 此 时 仿 转 电极 上 的 电压 为 去 ,墨水 小 滴 穿 过 挡 板 的 小 孔 ,喷射 在 记录 纸 上 。 如 果 不 布 望 印 
字 , 就 在 偶 转 电极 上 加 士 400V 的 电压 ,使 墨水 滴 发 生 偶 转 ,喷射 在 挡 板 上 ,经 墨水 回收 管 流 
入 废 墨水 瓶 中 。 连 续 式 喷 墨 系统 具有 频率 啊 应 高 ,可 实现 高 速 打印 等 优点 。 但 是 ,这 种 打印 
机 的 结构 比较 复杂 ,对 墨水 需要 加 奈 装 置 , 终 闪 要 有 回收 装置 来 回收 不 参与 印字 的 墨水 滴 ， 
在 墨水 循环 过 程 中 需要 设置 过 滤 硕 以 过 滤 混 和 人 的 杂质 和 和 气体。 采用 这 种 技术 的 喷 墨 打印 机 
目前 市 场 上 已 经 极 少见 到 。 


2. 随机 式 喷 墨 技 术 


随机 式 喷 墨 打印 机 的 墨 滴 只 有 在 需要 打印 时 才 从 喷 跨 中 嘎 出 (又 称 按 需 式 喷 墨 打印 
机 ) ,因而 不 需要 过 滤 关 和 复杂 的 墨水 循环 系统 。 由 于 受 射 流 惯性 的 影响 ,墨水 的 喷射 速度 
低 于 连续 式 嘎 墨 打印 机 。 为 了 提高 喷射 速度 ,喷头 一 般 由 多 个 喷嘴 组 成 ,其 结构 和 排列 与 针 
式 打 印 机 的 打印 头 相 似 。 随 机 式 喷 墨 打印 机 又 可 分 为 压 电 式 和 气泡 式 两 种 。 

压 电 式 喷 墨 打 印 机 的 喷头 内 准 有 墨水 ,在 喷 路 上 下 两 侧 各 放置 有 一 块 奈 电 陶 次 ,利用 它 
在 电压 作用 下 会 发 生 形 变 的 原理 ,适时 地 把 电压 加 到 它 的 上 面 , 使 其 变形 产生 压力 , 挤 压 喷 
头 喷 出 墨 滴 ,在 输出 介质 表面 形成 图 案 。 用 压 电 喷 墨 技术 制作 的 喷 墨 打印 头 成 本 比较 高 ,为 
了 降低 用 户 的 使 用 成 本 ,一 般 都 将 打印 头 和 墨盒 做 成 分 离 的 结构 ,更 换 墨 水 时 不 必 更 换 打 

气泡 式 打印 机 在 喷头 上 设置 了 加 热 元 件 。 当 脉冲 作用 于 加 热 元 件 上 ,加 热 元 件 急 速 升 
温 , 将 喷头 中 的 一 部 分 墨汁 气 化 ,形成 一 个 具有 喷射 力量 的 气泡 ,并 将 墨水 顶 出 喷 到 输出 介 
质 表 面 ,形成 图 案 或 字符 。 采 用 这 种 技术 的 打印 喷头 通 和 帝都 与 墨盒 做 在 一 起 ,更 换 墨 盒 时 即 
同时 更 新 打印 头 。 为 降低 使 用 成 本 ,在 墨盒 刚刚 用 完 , 可 立即 加 注 专用 的 墨水 ,只 要 方法 得 
当 , 可 以 节约 耗材 费用 。 

通 篆 所 说 的 喷 墨 打印 机 是 指 液态 喷 墨 打印 机 , 它 具 有 整 机 价格 低 、 工 作品 音 低 . 耗 电 少 、 


更 
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重量 轻 、 输 出 印字 质量 接近 低档 的 激光 打印 机 每 优点 ,同时 又 能 实现 廉价 的 真 彩色 打印 。 与 
针 式 打印 机 相 比 , 喷 墨 打印 机 对 墨水 的 质量 要 求 很 高 ,使 得 耗材 的 成 本 较 高 ,而 且 墨 水 大 多 
怕 受 潮 。 

除 液 态 喷 墨 打 印 机 外 ,还 有 一 种 固态 喷 黑 打印机。 固态 喷 墨 技术 是 Tektronix( 泰 殉 ) 
公司 于 1991 年 推出 的 专利 技术 , 它 所 使 用 的 相 变 墨 在 室温 下 可 变 为 固态 ,打印 时 墨 被 加 热 
液化 后 喷射 到 介质 上 , 巾 于 此 种 墨 附 痢 性 好 、 色 彩 鲜 完 .耐水 性 能 好 ,并且 不 存在 打印 头 因 黑 
水 干 酒 而 造成 的 堵塞 问题 。 但 是 ,采用 固态 油墨 的 打印 机 目前 因 生 产 成 本 比较 高 ,所 以 产品 
比较 少 。 


8.9.5 激光 打印 机 工作 原理 


激光 打印 机 是 一 种 光 、 机 、 电 一 体 、 高 度 自动 化 的 计算 机 输出 设备 ,其 成 像 原 理 与 静电 复 
印 机 相似 ,结构 比 针 式 打印 机 和 噶 墨 打印 机 都 复杂 得 多 。 它 主要 由 激光 带 、 激 光 扫 描 系 统 、 
以 矶 粉 与 感光 至 为 主 的 左 粉 盒 、 字 形 发 生 器 、 电 子 照相 转 印 机 构 和 电路 部 分 组 成 ,如 
图 8-14 所 示 。 


激光 扫描 | 电子 照 像 
图 8-14 激光 打印 机 的 组 成 


感光 鼓 是 激光 打印 机 的 核心 ,这 是 一 个 用 铝 合金 制 成 的 圆 简 ,其 表面 镀 有 一 层 半 导体 感 
光 材 料 ,通常 是 硒 ,所 以 又 常 将 它 称 为 硒鼓 。 激 光 打 印 机 的 打印 过 程 中 的 6 个 步骤 : 充电 、 
扫描 上 曝光、 显影 、 转 印 、 定 影 和 清除 残 像 都 是 于 绕 感 光 鼓 进行 的 。 

充电 : 对 硒鼓 进行 充电 ,使 其 表面 均匀 地 带 上 正 ( 负 ) 电 和 荷 。 

@O) 扫描 曝光 : 扫描 曝光 也 可 以 叫做 “书写 ”, 巾 控制 电路 控制 激光 束 对 硒鼓 表面 进行 扫 
描 照射 ,在 需 印 出 内 容 的 地 方 关 闭 激光 束 ,在 不 需 印 出 的 地 方 打开 激光 束 。 随 着 带 正 ( 负 ) 电 
荷 的 感光 鼓 表 面 的 转动 , 遇 有 激光 源 照射 时 , 避 表 面 曝 光 部 分 变 为 恨 导 体 , 产 生 光 电流 ,使 其 
失去 表面 电荷 。 而 未 曝光 的 鼓 表 面 仍 保留 电 蓓 ,从 而 在 硒鼓 上 形成 静电 “ 潜 像 ”。 

G) 显影 : 带 有 “ 潜 像 ”的 硒鼓 表面 继续 运动 ,通过 碳 粉 盒 时 ,带电 荷 的 部 分 吸附 上 碳 粉 ， 
从 而 在 鼓 面 上 显影 成 可 见 的 字符 碳 粉 图 像 。 

由 转 印 : 显影 的 表面 同 打印 纸 接 触 时 ,在 外 电场 的 作用 下 , 碳 粉 被 吸附 到 纸 上 ,完成 图 
像 的 转 印 。 

@ 定 影 : 分 离 后 的 纸 经 定 影 热 辊 , 碳 粉 在 高 温和 高 压 下 熔化 而 永久 性 地 黏附 在 纸 上 ， 
实现 定 影 而 得 到 最 终 的 印字 输出 结果 。 

@ 消除 残 像 : 完成 转 印 后 ,硒鼓 表面 还 留 有 残余 的 电荷 和 碳 粉 , 先 经 过 放电 将 电荷 中 
和 ,然后 经 过 清扫 辊 除去 残留 的 碳 粉 。 这 样 ,硒鼓 便 恢 复原 来 的 状态 ,以 便 进行 下 一 次 印字 
过 程 。 

由 于 激光 束 扫描 速度 可 以 很 高 ,而 且 打 印 输 出 是 随 硒鼓 转动 连续 进行 的 ,所 以 打印 速度 
较 快 ,是 逐 页 罗 出 的 ,因而 激光 打印 机 也 营 称 为 页 式 打 印 设 备 。 
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8.10 显示 设备 


显示 设备 是 将 电信 号 转换 成 视觉 信号 的 一 种 装置 。 在 计算 机 系统 中 ,显示 设备 被 用 作 
输出 设备 和 人 机 对 话 的 重要 工具 。 与 打印 机 等 便 找 贝 输出 设备 不 同 ,显示 副 输 出 的 内 容 不 
能 长 期 保存 , 当 显 示 带 关机 或 显示 别 的 内 容 时 , 原 有 内 容 就 消失 了 ,所 以 显示 设备 属于 软 找 
贝 输出 设备 。 


8.10.1 显示 器 概述 


计算 机 系统 中 的 显示 设备 , 耕 按 显示 对 象 的 不 同 可 分 为 字符 显示 右 、 图 形 显示 器 和 图 像 
显示 器 。 字 符 显 示 顺 是 指 能 显示 有 限 字 符 形 状 的 显示 需 。 图 形 和 图 像 是 既 有 区 别 又 有 联系 
的 两 个 概念 ,图 形 是 指 以 几何 线 、 面 、 体 所 构成 的 图 ;而 图 像 是 指 模拟 自然 景物 的 图 ,如 照片 
等 。 从 显示 角度 看 ,它们 都 是 由 像素 ( 光 点 ) 组 成 的 。 如 果 以 点 阵 方式 显示 字符 , 则 图 形 图 像 
显示 器 也 能 覆盖 字符 显示 需 的 功能 。 事 实 上 目前 常用 的 CRT 显示 器 都 具有 两 种 显示 方 
式 : 字符 方式 和 图 形 方式 ,所 以 它们 既是 字符 显示 器 ,又 是 图 形 图 像 显 示 器 。 

各 按 显 示 需 件 的 不 同 显示 设备 可 分 为 阴极 射线 管 (CCRT) 、 等 离子 显示 关 (PD) 发光 二 
极 管 显示 硕 (CLED) 、 场 致 发 光 显示 帮 (ELD) 液晶 显示 需 (CLCD) 、 电 致 变色 显示 大 (ECD) 和 
电泳 显示 器 (EPID) 等 。 这 些 显示 器 件 按 显示 原理 可 分 为 两 类 : 一 类 是 主动 显示 器 件 ,如 
CRT 显示 器 ,发光 二 极 管 显示 器 等 ,它们 是 在 外 加 电信 号 作用 下 ,依靠 器 件 本 身 产生 的 光 辐 
射 进 行 显 示 的 ,因此 也 称 为 光 发 射 希 件 ; 另 一 类 称 为 被 动 显示 需 件 ,如 液晶 显示 需 , 这 类 融 件 
本 身 不 发 光 , 工 作 时 需 另 设 光 源 ,在 外 加 电信 号 的 作用 下 ,依靠 材料 本 身 的 光学 特性 变化 ,使 
照射 在 它 上 面 的 光 受 到 调制 ,因此 这 类 器 件 又 称 为 光 调制 器 件 。 

计算 机 系统 中 使 用 最 广泛 的 是 CRT 显示 右 和 液晶 显示 器。CRT 显示 器 具有 成 本 较 
低 、 亮 度 高 .色彩 鲜明 真实 分辨 率 高 ,性 能 稳定 可 靠 等 优点 ;但 也 存在 着 体积 大 、 笨 重 、 功 耗 
大 等 缺点 。 液 晶 显 示 需 则 体积 小 .重量 轻功 耗 低 、 辐 射 小 ,但 亮度 较 低 ,色彩 不 够 鲜明 , 且 成 
本 较 高 。 随 着 生产 工艺 的 不 断 改 进 ,液晶 显示 器 的 价格 不 断 下 降 ,逐渐 普及 ,而 为 普通 用 户 
所 使 用 的 CRT 显示 需 却 已 在 2010 年 停产 。 目 前 CRT 显示 絮 的 用 途 , 仅 限于 一 些 有 特殊 需 
求 的 专业 领域 , 像 军用 、 医 用 、 航 天 等 方面 。 但 是 ,CRT 显示 器 具有 的 可 视角 度 大 、 无 坏 点 、 
色彩 还 原 度 高 . 色 度 均匀 、 可 调节 的 多 分 辨 率 模 式 、 啊 应 时 间 极 短 等 绝对 的 优势 仍 是 液晶 显 
示 器 所 无 法 替代 的 。 


8.10.2 CRT 显示 和 器 


随 着 计算 机 技术 的 发 展 和 应 用 的 拓展 ,CRT 显示 器 的 发 展 也 很 快 ,从 20 世纪 80 年 代 
初 到 现在 ,CRT 显示 器 的 分 辨 率 已 从 320X200 发 展 到 1024X768, 有 的 达到 1280 X1024 和 
1600X1200 以 上 ;颜色 也 由 单 色 发 展 到 16M 色 ; 显 像 管 的 点 距 从 0. 6mm 以 上 发 展 到 
0.21mm 以 下 ; 行 扫描 频率 从 15. 8kHz 发 展 到 120kHz 以 上 ;显示 屏幕 尺寸 从 12in 发 展 到 
20in 以 上 ;显示 屏幕 也 越 来 越 平面 化 。 目 前 的 CRT 显示 器 已 朝 着 高 分 辨 率 、 高 亮度 .平面 
化 大 屏 戎 、 低 辐射 等 方 各 发展。 

CRT 显示 器 由 显示 适配器 (显卡 ) 和 显示 器 (监视 器 ) 两 部 分 组 成 ,显卡 通常 插 在 微机 的 


可 坟 oo 加 
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总 线 搬 槽 上 ,也 有 的 微机 主板 上 集成 了 显卡 电路 。 显 卡 到 显示 融通 过 显示 专用 接口 连接 。 
图 8-15 给 出 了 CRT 显示 需 的 组 成 示意 图 。 


总 线 扩展 槽 AGP 视频 信号 线 
8-15 CRT 显示 器 的 组 成 


1. CRT 显示 器 的 主要 技术 指标 


(1) 点 距 

点 距 (Dot Pitch) 是 指 屏幕 上 两 个 相 邻 的 同色 葡 光 点 之 间 的 距离 。 点 距 有 实际 点 距 、 垂 
直 点 距 和 水 平 点 距 的 差别 ,如 图 8-16 所 示 , 严 格 意义 上 
的 点 距 是 指 实际 点 距 。 点 距 越 小 ,显示 的 画面 就 越 清晰 、 
自然 和 细腻 。 用 显示 区 域 的 宽 和 高 分 别 除 以 水 平 点 距 和 
垂直 点 距 , 即 得 到 显示 需 在 水 平和 垂直 方向 上 最 高 可 以 
显示 的 点 数 ( 即 极限 分 辩 率 )。 如 果 超 过 这 个 模式 ,屏幕 
上 的 相 邻 像素 会 互相 干扰 ,反而 使 画面 模糊 不 清 。 早 期 
的 14in 显示 器 的 点 距 分 为 0.28mm、0. 31mm 、0. 39mm 图 8-16 CRT 显示 器 的 点 距 
几 种 规格 ,目前 高 清晰 度 大 屏幕 显示 器 通常 采用 0. 20 一 
0.28mm 的 点 距 。 

(2) 行 频 和 场 频 

行 频 又 称 水 平 扫 描 频 率 , 是 电子 枪 每 秒 在 屏幕 上 扫描 过 的 水 平 线条 数 ,以 kHz 为 单位 。 
场 频 又 称 垂 直 扫描 频率 ,是 每 秒 屏幕 重复 绘制 显示 画面 的 次 数 ,以 Hz 为 单位 。 通 常 , 行 频 
二 水 平 线 行 数 X 场 频 。 

由 于 显示 需 需 要 与 显卡 匹配 ,所 以 现在 所 有 的 显示 器 都 是 变频 的 (也 称 多 扫描 或 多 频 )。 
频率 的 范围 越 大 则 显示 器 越 喧 ,其 用 途 也 越 广 。 场 频 决 定 了 图 像 的 稳定 性 ,频率 越 高 越 好 ， 
典型 的 场 频 为 50 一 160Hz, 但 是 它 还 与 分 辨 率 密切 相关 ,如 当 分 辨 率 为 640X480 时 , 某 显 示 
器 的 场 频 可 达到 100Hz, 而 当 分 辨 率 为 1024X768 时 , 场 频 将 降 至 60Hz。 行 频 通常 为 31.5 
一 90kHz 或 更 高 ,目前 比较 主流 的 行 频 有 70kHz、85kHz、96kHz 等 。 

(3) 视频 带宽 

视频 带宽 是 表示 显示 需 显 示 能 力 的 一 个 综合 性 指标 ,以 MHz 为 单位 。 它 指 每 秒 扫描 
的 像素 个 数 , 即 单位 时 间 内 每 条 扫描 线 上 显示 的 点 数 的 总 和 。 和 带宽 越 大 表明 显示 器 显示 控 
制 能 力 越 强 ,显示 效果 越 佳 。 现 在 主流 的 CRT 显示 器 的 视频 带宽 都 能 达到 110MHz 以 上 ， 
高 档 显 示 需 的 带宽 可 达 200MHz 以 上 。 

视频 带宽 王 水 平分 辨 率 义 垂直 分 辨 率 义 场 频 义 1.344 
其 中 ,常数 1. 344 表示 电子 枪 在 扫描 时 扫 过 水 平方 向 上 的 像素 点 数 与 垂直 方向 上 的 像素 点 
数 均 应 当 高 于 理论 值 ,这 样 才能 避免 信号 在 扫描 边缘 衰减 ,使 图 像 四 周 同 样 清 晰 。 
(4) 最 高 分 辩 率 
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最 高 分 辨 率 是 定义 显示 需 画 面 解析 度 的 标准 ,由 每 帧 画面 的 像素 数 决定 ,以 水 平 显示 的 
像素 个 数 X 水 平 扫 描 线 数 表示 。 例 如 ,800X600 表示 一 幅 画 面 水 平方 向 和 垂直 方向 的 像素 
点 数 分 别 是 800 和 600。 最 高 分 辩 率 不 仅 与 显示 尺寸 有 关 , 还 受到 点 距 和 视频 带宽 等 因素 
的 制约 。 值 得 一 提 的 是 ,一 台 显 示 器 在 75Hz 以 上 的 场 频 下 所 能 达到 的 分 辨 率 才 是 它 真 正 
的 最 高 分 辨 率 。 

(5) 刷新 率 

刷新 率 实 际 上 就 等 于 场 频 ,刷新 率 越 高 ,意味 着 屏幕 的 闪烁 越 小 ,对 人 有 眼睛 产生 的 刺激 
越 小 。 行 频 、 场 频 . 最 高 分 辨 率 这 几 个 参数 息息相关 。 一 般 来 说 , 行 频 、 场 频 的 范围 越 宽 ,能 
达到 的 最 高 分 辩 率 也 越 高 ,相同 分 辩 率 下 能 达到 的 最 高 刷新 率 也 越 高 。 早 期 显示 器 只 支持 
50 一 60Hz 的 刷新 率 ,现在 VESA( 视 频 电子 标准 协会 ) 规 定 85Hz 为 无 闪烁 的 刷新 率 , 从 保 
护 眼 睛 的 角度 出 发 ,刷新 率 越 高 越 好 。 

(6) 屏幕 尺寸 

指 屏 幕 对 角 线 长 度 , 一 般 有 14in、15in、17in、19in、20in、21in 等 。 


2. CRT 显示 原理 


(1) CRT 显示 需 的 扫描 方式 

CRT 显示 硕 如 同 电视 接收 机 一 样 , 普 过 采用 光栅 扫 拉 方式。 在 光栅 扫描 方式 中 ,电子 
束 在 水 平和 垂直 同步 信号 的 控制 下 有 规律 地 扫描 整个 屏幕 。 扫 摘 的 方法 如 下 : 电子 束 从 显 
示 屏 的 左上 角 开 始 , 沿 水 平方 器 从 左 癌 右 扫 描 ,到 达 屏 磊 右 端 后 迅速 水 平 回 扫 到 左 端 下 一 行 
位 置 ,又 从 左 到 右 匀 速 地 扫描 。 这 样 一 行 一 行 地 扫 
描 , 直 到 屏幕 的 右 下 角 ,然后 又 垂直 回 扫 ,返回 屏幕 左 
上 角 ,重复 前 面 的 扫 拉 过程。 在 水 平和 垂直 回 扫 时 ， 
电子 束 是 “ 消 隐 ?的 , 葡 光 屏 上 没有 亮光 显示 。 这 样 ， 
在 CRT 的 屏幕 上 形成 了 一 条 条 水 平 扫描 线 , 称 为 光 
栅 。 图 8-17 为 光栅 扫描 示意 图 ,图 中 的 虚线 表示 消 
隐 的 水 平和 垂直 回 扫 线 。 图 8-17 ”光栅 扫描 

一 幅 光 栅 通 常 也 叫做 一 帧 ,一 帧 画面 的 扫描 行 数 
越 多 ,显示 出 来 的 画面 就 越 清晰 。 但 要 使 扫描 行 数 二 多 , 则 须 使 行 扫 描 频率 增高 , 当 要 求 太 
高 时 就 难于 实现 。 显 示 大 中 有 两 种 可 能 的 方法 : 巡 行 扫描 与 隔行 扫描 。 

从 上 加 下 依次 顺序 扫 摘 出 所 有 的 行 扫 摘 线 称 为 逐 行 扫 摘 , 扫 完 一 场 即 为 一 帧 。 这 种 方 
式 的 控制 比较 简单 ,画面 质量 较 好 且 稳 定 ,但 对 行 扫 描 频 率 要 求 较 高 。 

将 一 帧 画面 分 为 奇数 场 和 偶数 场 ,奇数 行 组 成 奇数 场 ,偶数 行 组 成 偶数 场 。 第 一 场 显 示 
奇数 行 ,第 二 场 显 示 侦 数 行 的 过 程 称 为 隔行 扫描 ,扫描 一 帧 画面 需要 两 场 。 如 果 每 一 帧 总 行 
数 不 变 以 维持 所 要 求 的 分 状 率 , 则 每 一 场 的 行 数 将 减少 一 半 , 相 应 的 行 扫 描 频率 也 将 降低 一 
半 。 由 于 一 帧 由 两 场合 成 ,所 以 画面 质量 较 逐 行 扫描 方式 稍 差 一 些 。 目 前 ,微机 中 的 显示 大 
一 般 采 用 逐 行 扫描 方式 。 

(2) 显示 需 的 显示 模式 

显示 模式 从 功能 上 分 为 两 大 类 : 字符 模式 和 图 形 模 式 。 

字符 模式 也 称 字 母 数 字模 式 , 即 A/N 模式 (Alpha Number Mode)。 在 这 种 模式 下 , 显 
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示 缓 冲 区 中 存放 着 显示 字符 的 代码 (ASCII 码 ) 和 属性 。 显 示 屏 幕 被 划分 为 若干 个 字符 显示 
行 和 列 , 如 80 列 X25 行 。 

由 于 字符 模式 在 CRT 显示 器 上 不 是 点 控制 ,而 是 一 个 由 8 位 代码 (ASCII 码 ) 控 制 的 一 
块 , 如 像 8X8、8X14 等 大 小 的 显示 区 域 。 因 此 显示 缓冲 区 较 小 ,显示 更 新 的 速度 非常 快 ,但 
缺点 是 无 法 显示 图 形 。 目 前 流行 的 所 有 显卡 都 包含 字符 模式 。 

图 形 模式 也 称 APA 模式 (All Points Addressable Mode) , 即 对 所 有 点 均 可 寻 址 。 通 常 
把 它 称 为 位 图 化 的 显示 需 , 因 为 屏幕 上 的 每 个 像素 都 对 应 显示 缓冲 区 中 的 一 位 或 多 位 。 

(3) 显示 缓冲 区 

荧光 屏 上 涂 的 是 中 短 余 辉 菊 光 材 料 ,否则 会 导致 图 像 变 化 时 前 面 图像 的 残 影 浪 留 在 屏 
幕 上 ,但 如 此 一 来 ,就 要 求 电子 枪 不 断 地 反复 “点 亮 交 烛 灭 ? 灾 光 点 ,即便 屏幕 上 显示 的 是 静 
止 图 像 ,也 照常 需要 不 断 地 刷新 。 

为 了 不 断 提 供 刷 新 画面 的 信号 ,必须 把 字符 或 图 形 信息 存储 在 一 个 显示 缓冲 区 中 ,这 个 
缓冲 区 又 称 为 视频 存储 器 (VRAM)。 显 示 器 一 方面 对 屏幕 进行 光栅 扫描 , 男 一 方面 同步 地 
从 VRAM 中 读 取 显示 内 容 , 送 往 显 示 需 件 。 因 此 ,对 VRAM 的 操作 是 显示 器 工作 的 软 、 便 
件 界 面 所 在 。 

VRAM 的 容量 由 分 辩 率 和 灰 度 级 决定 ,分 辨 率 越 高 , 灰 度 级 越 高 ,VRAM 的 容量 就 越 
大 。 同 时 ,VRAM 的 存 取 周期 必须 满足 刷新 率 的 要 求 。 

分 辨 率 由 每 帧 画面 的 像素 数 决 定 ,而 像素 具有 明暗 和 色彩 属性 。 黑 日 图 像 的 明暗 程度 
称 为 灰 度 ,明暗 变化 的 数量 称 为 灰 度 级 ,所 以 在 单 色 显示 需 中 , 仅 有 灰 度 级 指标 。 彩 色 图 像 
是 由 多 种 颜色 构成 的 ,不 同 的 深浅 也 可 算 作 不 同 的 颜色 ,所 以 在 彩色 显示 需 中 能 显示 的 颜色 
种 类 称 为 颜色 数 。 如 果 颜 色 数 较 少 ,不 足以 逼真 地 显示 图 像 , 则 称 为 伪 彩 色 显 示 。 如 果 颜 色 
数量 多 ,显示 通 真 , 则 称 为 真 彩色 显示 。 真 彩色 一 般 要 求 调 色 板 能 达到 显示 2 关 王 16M(1677 
万 ) 种 颜色 的 能 力 。 

在 字符 显示 方式 中 ,将 一 屏 中 可 显示 的 最 多 字符 数 称 为 分 辨 率 。 例 如 ,80 列 X25 行 表 
示 每 屏 最 多 可 显示 25 行 , 每 行 可 有 80 个 字符 。 字 符 方式 的 VRAM 通常 分 成 两 部 分 : 字符 
代码 缓存 和 显示 属性 缓存 。 字 符 代 码 缓存 中 存放 着 显示 字符 的 ASCII 码 , 每 个 字符 占 1 个 
字 节 ;显示 属性 缓存 中 存放 着 字符 的 显示 属性 ,一 般 也 占 1 个 字 节 。VRAM 的 最 小 容量 是 
由 屏幕 上 字符 显示 的 行 、 列 规格 来 决定 的 。 例 如 ,一 帧 字符 的 显示 规格 为 80 X 25, 那 么 
VRAM 中 的 字符 代码 缓存 的 最 小 容量 就 是 2KB。 缓 存 的 容量 也 可 以 大 于 一 帧 字符 数 ,用 来 
同时 存放 几 帧 字符 的 代码 。 在 这 种 情况 下 ,通过 控制 缓存 的 指针 就 可 以 在 屏幕 上 显示 不 同 
帧 中 的 字符 内 容 , 实 现 屏幕 的 硬件 深 动 。 

在 图 形 显示 方式 中 ,将 一 屏 中 可 显示 的 像素 点 数 称 为 分 辨 率 ,图 形 方式 的 显示 信息 以 二 
进 制 的 形式 存储 在 VRAM 中 ,这 些 信 息 是 图 形 元 素 的 矩阵 数组 ,在 最 简单 的 情况 下 ,只 需 
要 存储 两 值 图 形 , 即 用 “0” 表 示 黑 色 ( 暗 点 ) ,用 “1” 表 示 白 色 ( 亮 点 )。 用 VRAM 的 1 位 表示 
1 个 点 ,所 以 YRAM 的 1 个 字 节 可 以 存放 8 个 点 。 例 如 ,一 个 CRT 显示 如 的 分 辨 率 为 640 
X200 ,在 无 灰 度 级 的 单 色 显示 器 中 ,只 需要 16KB 的 VRAM。 在 彩色 显示 或 单 色 多 灰 度 显 
示 时 ,每 个 点 需要 若干 位 来 表示 。 例 如 , 若 用 两 位 二 进 制 代码 表示 1 个 点 ,那么 每 个 点 便 能 
选择 显示 4 种 颜色 ,但 是 此 时 VRAM 的 1 个 字 节 只 能 存放 4 个 点 ,如 果 显 示 需 的 分 辨 率 不 
变 ,VRAM 的 容量 就 要 增加 一 倍 。 反 之 , 若 VRAM 容量 一 定 , 则 随 着 分 辨 率 的 增高 ,显示 
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的 颜色 数 将 减少 。 
在 图 形 方 式 下 ,VRAM 中 用 于 存放 每 个 像素 点 颜色 信息 的 位 数 称 为 颜色 深度 或 色彩 深 
度 ,颜色 深度 与 颜色 数 的 对 应 关系 为 : 
颜色 深度 二 log;s 颜色 数 


8. 10.3 字符 显示 器 的 工作 原理 
1. 字符 显示 原理 


字符 显示 需 显 示 字 符 的 方法 也 是 以 点 阵 为 基础 的 。 通 常 将 显示 屏幕 划分 成 许多 方块 ， 
每 个 方块 称 为 一 个 字符 窗口 , 它 包 括 字 符 显 示 上 点 阵 和 字符 间 隅 。 一 般 的 字符 显示 硕 可 显示 
80 列 X25 行 =2000 个 字符 ,字符 窗口 数目 为 80X25, 如 图 8-18 所 示 。 在 单 色 字符 显示 方 
式 下 ,每 个 字符 窗口 为 9X14 点 阵 , 对 应 的 分 辨 率 为 80 列 X25 行 (720X350 点 阵 ), 其 中 了 字 
和 从 本 身 点 阵 为 7X9, 同 一 字符 行 中 字符 横 癌 间隔 两 个 点 ,不同 字符 行 间 的 间隔 为 5 个 点 。 

屏幕 上 每 个 字符 窗口 对 应 于 VRAM 中 的 一 个 字 节 单元 ,在 实际 的 VRAM 中 ,还 需 存 
入 字符 的 显示 属性 ,所 以 VRAM 的 容量 还 需 增 加 一 倍 。VRAM 中 存放 的 是 字符 的 ASCII 
码 , 不 是 点 阵 信息 。 奋 要 显示 出 字符 的 形状 ,还 要 有 字符 发 生 器 (字符 库 ) 的 文 持 。 

显示 需 的 字符 库 是 用 来 存放 各 种 字符 的 点 阵 字 形 辉 亮 数据 的 只 读 存 储 硕 。 显 示 时 ,从 

ROM 中 读 出 有 关 的 点 阵 信 息 送 给 CRT 作为 辉 亮 控 制 信号 ,以 控制 电子 束 的 强 弱 ,从 而 在 
屏 莽 上 组 成 字符 。 显 示 需 的 字符 库 中 存放 的 是 字符 的 行 点 阵 码 ,字符 库 的 高 位 地 址 来 月 
VRAM 的 ASCII 码 ,低位 地 址 来 自行 计数 需 的 输出 RA; 一 RAo( 行 扫描 线 序号 )。 图 8-19 
给 出 了 字符 “A” 的 点 阵 字 形 , 这 是 一 个 7X9 的 点 阵 , 用 二 进 制 码 中 的 “1” 对 应 屏幕 上 的 亮 
点 ,0” 对 应 瞳 点 。 对 于 字符 “A” 可 用 9 个 字 节 的 行 点 阵 码 表示 ,从 第 一 行 到 第 九 行 分 别 为 
10H、28H、44H、82H、82H、FEH、82H、82H、00H。 从 字符 库 中 读 出 行 点 阵 码 ,就 能 显示 出 


ASCII(41H) 
指 回 这 个 字形 


23| 1840 1841 1842 .…， 1919 
24| 1920 1921 1922 RE 1999 


图 8-18 屏幕 上 字符 位 置 的 分 配 图 8-19 “A” 的 点 阵 字 形 


在 屏幕 上 ,每 个 字符 行 要 显示 多 个 字符 ,而 电子 束 在 光栅 扫描 时 ,采用 的 是 逐 行 扫描 法 。 
按照 这 种 扫描 法 ,在 显示 字符 时 ,并 不 是 对 显示 的 每 个 字符 单独 进行 点 阵 扫 描 ( 即 扫描 完 一 
个 字符 的 各 行 点 阵 , 青 扫描 男 一 个 字符 的 各 行 点 阵 ) ,而 是 采用 对 一 排 所 有 字符 的 点 阵 进行 
逐 行 依次 扫 摘 。 例 如 , 茶 字 符 行 欲 显示 的 字符 是 A,B,C,…,T, 显 示 电 路 首先 根据 各 字符 代 
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码 依 次 从 字符 发 生 带 取出 A,B,C,…'TI 各 个 字符 的 第 一 行 点 阵 代码 ,并 在 字符 行 第 一 条 扫 
描 线 位 置 上 显示 出 这 些 字符 的 第 一 行 点 阵 ; 然 后 再 依次 取出 该 排 各 个 字符 的 第 二 行 代码 ,并 
在 屏 梨 上 扫 出 它们 的 第 二 行 点 阵 。 如 此 循环 ,直到 扫描 完 该 字符 行 的 全 部 扫描 线 , 那 么 每 个 
字符 的 所 有 点 阵 ( 如 9 行 点 阵 ) 便 全 部 显示 在 相应 的 位 置 上 ,屏幕 上 就 出 现 了 一 排 完 整 的 字 
符 。 当 显示 下 一 排 字 符 时 ,重复 上 述 的 扫描 过 程 。 


2. VRAM 的 地 址 组 织 


在 字符 显示 器 中 ,屏幕 上 每 个 字符 位 置 对 应 VRAM 中 的 一 个 字 节 ,VRAM 中 各 字 节 
单元 的 地 址 随 着 屏幕 由 左 向 右 , 自 上 而 下 的 显示 顺序 从 低 向 高 安排 。 也 就 是 说 ,VRAM 的 
0 号 单元 存放 的 字符 代码 经 字符 发 生 硕 转换 为 字形 点 阵 后 ,显示 在 屏 才 第 一 行 字 符 左 边 第 
一 个 位 置 上 ;1 号 单元 存放 的 字符 代码 转换 后 显示 在 屏幕 第 一 行 左 边 的 第 二 个 位 置 上 …… 
VRAM 的 最 后 一 个 单元 存放 的 字符 代码 转换 后 显示 在 屏幕 最 后 一 行 右边 最 末 一 个 位 置 上 。 
VRAM 的 地 址 安排 与 屏 人 项 位 置 的 对 应 关系 如 图 8-20 所 示 。 


VRAM 


8-20 ”VRAM 的 地 址 安排 与 屏幕 位 置 的 对 应 关系 


3. 字符 显示 器 的 控制 电路 


图 8-21 是 字符 显示 需 的 定时 控制 电路 。 它 的 核心 是 点 计数 需 、 字 计数 需 ( 水 平地 址 计 
数 器 )., 行 计数 器 和 排 计数 器 (垂直 地 址 计数 器 ) ,由 它们 来 控制 显示 需 的 逐 点 、 逐 字 、 逐 行 、 逐 
屏幕 的 刷新 显示 。 为 了 避免 扫 摘 行 和 字符 行 这 两 个 概念 的 混 消 ,在 下 例 中 把 扫描 行 仍 称 为 
行 ,而 把 字符 行 称 为 排 。 

每 次 从 字库 中 读 出 一 行 字 符 点 数据 7 位 , 送 入 移 位 寄存 器 ,然后 在 点 脉冲 控制 下 上 串 行 
地 移 位 输出 , 送 往 显示 器 作为 亮度 控制 信号 :“1? 亮 “02 暗 。 移 位 寄存 器 实现 并 一 串 转换 ， 
每 发 一 个 点 脉冲 ,屏幕 上 产生 一 个 像 点 。 

点 计数 需 对 一 个 字符 的 列 数 和 字符 横 癌 间 隅 进行 计数 ,为 9 分 频 , 即 输入 9 个 点 脉冲 后 
完成 一 次 计数 循环 ,并 向 下 一 级 计数 大 输出 一 个 计数 脉冲 ,这 对 应 于 一 个 字符 横 回 7 点 ,加 
上 两 点 间距 。 

字 计 数 器 用 来 同步 控制 一 条 水 平 扫 描 线 的 正 扫 和 回 扫 。 由 于 一 排 可 有 80 个 字符 , 需 在 
扫描 正 程 中 显示 ,所 以 当 字 计数 器 由 0 计 到 79 时 ,光栅 从 左 向 右 扫 满 一 行 。 然 后 进入 回 扫 
逆 程 , 设 逆 程 需 占 18 个 字符 扫描 时 间 ( 折 合 值 ), 因 此 字符 计数 器 为 (80 十 18) 二 98 分 频 , 即 
每 输入 98 个 计数 脉冲 完成 一 个 计数 循环 。 

行 计数 禹 对 字符 窗口 的 高 度 进行 控制 ,字符 窗口 的 高 度 所 占 的 扫描 线 数 为 14。CRT 
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每 完成 一 次 水 平 扫描 ,只 能 显示 一 排 字 符 中 的 一 行 。 只 有 依次 扫描 9 行 后 ,才能 完整 地 显示 
出 一 排 字符 ,再 扫描 5 行 并 消 隐 之 后 , 即 形 成 排 间 的 空白 间距 。 所 以 行 计数 器 为 (9 十 5) 二 14 

排 计数 器 对 应 于 屏幕 的 垂直 扫描 及 其 回 扫 。 正 程 显示 25 排 字符 , 当 排 计数 器 从 0 计数 
到 24 时 ,光栅 正好 从 上 向 下 扫 完 一 屏 ,然后 进入 回 扫 逆 程 , 回 到 屏幕 左上 角 。 逆 程 时 间 等 于 
扫描 一 排 字 符 的 时 间 ,折合 值 为 1, 所 以 计数 分 频 值 为 (25 十 1) = 二 26。 

显然 排 计 数值 体现 了 当前 显示 字符 的 排 号 , 字 计 数值 体现 了 当前 显示 字符 的 列 号 ,它们 
决定 了 字符 的 显示 位 置 。 因 此 巾 排列 号 可 转换 为 VRAM 的 地 址 , 据 此 找到 对 应 的 单元 ， 
取出 字符 代码 (ASCII 码 )。 该 字符 代码 作为 字符 库 的 高 位 地 址 ,而 行 计 数值 作为 低位 地 址 ， 
据 此 可 读 出 该 字符 点 阵 的 对 应 行 数 据 , 经 移 位 寄存 器 串 行 输出 ,放大 后 驱动 CRT 控制 栅 
极 ,决定 像 点 的 亮度 。 

字 计 数 器 的 一 个 循环 ,启动 CRT 行 扫 描 电 路 开始 新 的 一 行 水 平 扫描 。 排 计数 颖 的 一 
个 循环 ,启动 CRT 场 扫 描 电 路 开始 新 的 一 场 扫 描 。 


8.10.4 图 形 显示 器 的 工作 原理 


下 面 以 某 彩色 图 形 显 示 器 为 例 , 介 绍 图 形 显示 的 基本 原理 。 设 该 彩色 图 形 显示 器 的 分 
辩 率 为 640X480, 可 同时 显示 16 种 颜色 。VRAM 中 存放 着 显示 的 图 形 点 阵 数 据 , 由 于 计 
算 机 只 能 以 二 进 制 方式 存放 数据 ,每 位 只 有 两 种 状态 (“0” 或 “1”)。 对 于 单 色 显示 ,VRAM 
中 的 每 一 位 对 应 画面 上 的 一 个 像素 点 ,该 位 为 “1? 即 表示 画面 上 的 这 一 点 是 亮点 。 而 对 于 彩 
色 显 示 ( 如 16 种 颜色 ) ,就 需要 用 VRAM 中 的 4 位 来 定义 一 种 颜色 。 在 彩色 图 形 显示 器 中 
经 党 采用 彩色 位 平面 的 存储 结构 来 表示 颜色 信息 。 每 个 彩色 位 平面 由 单一 位 组 成 ,并 表示 
屏 上 某 个 可 以 显示 的 颜色 。 例 如 ,分 辩 率 为 640 X480, 每 个 位 平面 含有 640X480 位 , 即 有 
307 200 位 的 信息 。 由 于 要 同时 显示 16 种 不 同 颜色 , 它 就 具有 4 个 彩色 位 平面 , 故 需要 
1 228 800 位 的 VRAM, 即 153 600B。 所 以 ,VRAM 的 总 容量 ==640 X480X4b 守 150KB。 它 
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被 分 为 4 个 位 平面 ,每 个 位 平面 提供 彩色 代码 中 的 一 位 ,每 个 位 平面 的 容量 为 37. 5KB。 
从 屏幕 显示 角度 ,每 一 行 由 4 个 位 面 中 的 80 个 字 节 来 表示 (640/8 王 80) 。 屏 幕 上 的 一 
个 彩色 像素 点 ,需要 用 来 目 4 个 位 平面 上 每 个 位 平面 的 相同 位 置 的 一 个 存储 位 表示 。 


Eee 根据 上 述 对 应 关系 ,可 设计 出 显示 帮 控 制 逻辑 中 的 同步 计数 分 频 关 系 , 如 图 8-22 所 示 。 
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图 形 / 图 像 以 像素 为 单位 ,但 在 VRAM 中 以 字 节 为 单位 按 地 址 存储 ,即将 一 条 水 平 线 
上 上 月 左 回 右 ,每 8 个 点 的 代码 作为 一 个 字 节 ,存放 在 一 个 编 址 单元 中 。 因 此 ,点 脉冲 经 点 计 
数 关 8 分 频 之 后 产生 字 节 脉冲 ,每 发 一 次 字 节 脉冲 就 访问 一 次 VRAM, 从 4 个 位 平面 中 各 
读 出 一 个 字 节 (8 点 ) 送 往 移 位 寄存 带 , 上 骨 串 行 输出 形成 亮度 信号 与 红 、 绿 、 蓝 三 色 信 号 ,它们 
的 组 合 决定 了 16 色 中 的 一 种 。 知 用 于 单 色 显 示 器 , 则 将 4 位 代码 转换 为 16 级 亮度 调制 信 
号 ,用 于 控制 像素 的 灰 度 。 

列 计数 天 又 称 字 节 计 数 硕 ,98 分 频 。 计 数值 从 0 到 79 ,光栅 从 左 回 右 扫 摘 一 行 , 正 程 显 
示 80 个 字 节 共 640 点 。 字 节 计 数 器 所 附加 的 18 次 计数 作为 行 线 逆 程 回 扫 时 间 , 逆 程 回 扫 

行 计数 器 为 488 分 频 。 计 数值 从 0 到 479 ,对 应 于 场 正 程 扫描 ,显示 480 行 ; 附 加 8 次 计 
数 , 对 应 于 场 逆 程 回 扫 , 逆 程 回 扫 应 消 隐 。 

行 计数 值 与 列 计数 值 决 定 了 屏 右 当前 显示 位 置 (8 点 一 组 ), 相 应 的 VRAM 地 址 为 : 行 
号 X80 十 列 号 。 按 该 地 址 同时 访问 4 个 位 平面 ,取出 4 个 字 节 的 图 形 代 码 。 列 计数 一 个 循 
环 , 输 出 一 个 行 扫 描 同步 信号 ; 行 计 数 一 个 循环 ,输出 一 个 场 扫描 同步 信号 。 这 就 使 得 对 
VRAM 的 访问 与 CRT 的 扫 摘 严格 同步 ,能 获得 稳定 的 显示 画面 。 

从 以 上 的 分 析 可 以 看 出 ,分 辩 率 .颜色 数 与 VRAM 容量 密切 相关 。 对 于 字符 显示 方 
式 ,如果 分 辨 率 为 c 列 X1l 行 ,而 一 个 字符 的 编码 与 属性 、 颜 色 数 共 需 占 n 字 节 , 则 VRAM 
的 总 容量 应 不 少 于 cXlXn 字 节 。 对 于 图 形 显示 方式 ,如 果 分 辨 率 为 cX1 像素 ,而 每 个 像素 
的 颜色 数 用 nn 位 二 进 制 代 码 表示 , 则 VRAM 容量 应 不 少 于 cXlXn 位 。 两 种 显示 方式 的 c、 
/ 值 不 同 ,显然 ,图 形 方式 所 需 的 VRAM 容量 一 般 都 大 于 字符 方式 。 如 果 一 台 CRT 显示 需 
既 可 用 作 字 符 方 式 又 可 用 作 图 形 方 式 , 且 各 有 数 种 分 辨 率 规格 , 则 VRAM 的 容量 计算 应 以 
最 高 分 辨 率 图 形 方式 为 准 。 
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一 全 显示 融 可 以 显示 的 字符 种 类 与 字符 点 阵 规格 ,决定 了 字符 发 生 带 ROM 的 容量 大 
小 ,而 VRAM 的 容量 与 此 无 关 。 


8.10.5S LCD 显示 颂 


LCD(Liquid Crystal Display) 就 是 液晶 显示 器 ,LCD 有 低 胶 目的 全 平面 屏幕 ,需要 的 功 
率 很 低 , 有 源 阵 列 的 LCD 面板 的 色彩 质量 实际 上 超过 了 大 多 数 CRT 显示 需 。 


1. LCD 显示 原理 


LCD 显示 带 提 供 比 同 尺 寸 CRT 显示 希 更 大 的 可 视图 像 ,有 4 种 基本 的 LCD 选择 : 无 
源 阵 列 单 色 无 源 阵列 彩色 、 有 源 阵 列 模拟 彩色 和 最 新 的 有 源 阵 列 数字 彩色 。 无 源 阵列 的 单 
色 和 彩色 显示 屏 主要 是 用 作 早 期 低档 便携 式 计 算 机 的 显示 器 或 者 工业 用 的 果 面 显示 面板 ， 
与 有 源 阵列 模块 相 比 ,具有 相对 较 低 的 价格 和 较 强 的 耐用 性 。 

大 多 数 通 用 无 源 阵列 显示 费 采 用 超级 偏转 癌 列 型 设计 ,因此 这 些 面板 经 常 被 称 为 STN 
(Super Twist Nematic) 。 有 源 阵 列 显示 需 采 用 溥 膜 晶体 管 设计 ,因此 被 称 为 TFT(CThin 
Film Translstor) 。 

在 LCD 中 有 两 个 俩 振 天 , 偶 振 硕 只 人 允许 与 其 方 回 相同 的 光波 通过 ,经 过 俩 振 硕 后 的 光 
波 都 成 同一 方 回 。 通 过 改变 第 二 个 偏振 器 的 角度 ,人 允许 通过 的 光 数 量 可 以 改变 。 改 变 人 偏振 
角 和 控制 通过 的 光 数 量 ,就 是 液晶 单元 所 扮演 的 角色 。 在 彩色 LCD 中 , 男 有 一 个 附加 偏振 
天 为 每 个 像素 分 配 3 个 单元 ,分 别 显 示 红 、 绿 、 蓝 中 的 一 种 。 

液晶 单元 是 像 液体 一 样 可 以 流动 的 棒状 分 子 , 可 以 使 光线 直接 通过 ,但 是 电荷 可 以 改变 
品 体 的 方向 及 通过 它 的 光线 的 方向 。 尽 管 单 色 LCD 没有 彩色 偶 振 需 , 但 是 每 个 像素 有 多 个 
单元 来 控制 灰 度 的 深浅 。 

在 一 个 无 源 阵列 的 LCD 中 ,每 个 液晶 单元 被 两 个 品 体 管 的 电 奏 所 控制 , 它 取 决 于 品 体 
在 屏幕 上 的 行列 位 置 。 沿 着 屏幕 水 平和 垂直 边缘 的 晶体 管 数 目 决 定 了 屏 贿 的 分 辨 率 。 例 
如 ,一 个 具有 1024X768 分 辨 率 的 屏幕 ,在 水 平 边 界 有 1024 个 晶体 管 , 在 垂直 边缘 上 有 768 
个 晶体 管 ,总 共有 1792 个 。 当 液晶 单元 啊 应 自己 的 两 个 品 体 管 的 脉冲 时 ,将 对 光波 产生 偏 
转 , 电 和 荷 越 强 ,光波 偶 转 得 越 厉害 。 

在 无 源 阵列 LCD 中 的 电荷 是 脉冲 式 的 ,所 以 显示 需 缺 少 像 有 源 阵 列 那样 的 亮度 ,为 了 
增加 亮度 , 现 采 用 一 种 称 为 双 扫 摘 的 新 技术 ,将 无 源 阵 列 屏 必 分 为 上 半 部 和 下 半 部 ,让 两 个 
独立 电路 同时 驱动 显示 硕 的 上 半 部 和 下 半 部 ,减少 每 个 脉冲 之 间 的 间隔 时间。 除了 增加 有 亮 
度 , 双 扫 描 设 计 还 提高 了 响应 速度 ,使 这 种 类 型 对 于 全 动态 视频 或 其 他 显示 信息 快速 变化 的 
应 用 更 有 用 处 。 

在 有 源 阵 列 LCD 中 ,每 个 单元 在 显示 屏 之 后 有 自己 专用 的 品 体 管 ,对 其 充电 进而 偏转 
光波 。 于 是 ,一 个 1024X768 的 有 源 阵 列 显示 器 就 有 786 432 个 晶体 管 。 提 供 比 无 源 阵列 
显示 需 更 亮 的 图 像 , 因 为 各 单元 能 够 维持 一 个 恒定 的 、 较 长 时 间 的 充电 。 然 而 ,有 源 阵 列 技 
术 的 能 耗 比 无 源 阵列 的 大 ,有 源 阵列 显示 器 制造 起 来 比较 困难 ,价格 更 高 。 

在 有 源 和 无 源 阵列 LCD 中 ,第 二 个 依 振 颖 控制 通过 每 个 单元 的 光量 。 这 些 单 元 把 光线 
的 波长 偏转 到 接近 匹配 仿 振 器 允许 的 波长 。 每 个 单元 通过 偏振 器 的 光量 越 多 ,像素 越 亮 。 

单 色 LCD 显示 器 通过 改变 单元 的 亮度 或 者 以 开关 模式 高 频 振动 单元 来 获得 灰 度 级 别 


四 放生 
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(可 到 64 级 ) ,而 彩色 LCD 高 频 振动 3 个 彩色 单元 ,并 控制 它们 的 亮度 以 获得 屏幕 上 的 不 同 
颜色 。 

超 俩 转 和 三 重 超 偶 转 LCD 技术 的 出 现 使 得 用 户 能 够 从 更 大 的 角度 ,以 更 好 的 对 比 度 和 
亮度 清晰 地 观看 屏 有 大。 为 了 在 微 光 的 情况 下 改善 清晰 度 ,一 些 便携 机 加 入 了 育 光 和 侧 光 (也 
称 为 边 光 ) 。 育 光 屏 幕 从 LCD 后 面 的 面板 获取 光线 , 侧 光 屏 性 从 安装 在 屏 用 边缘 上 的 小 的 
严 光 管 获取 光线 。 

目前 ,最 好 的 彩色 显示 器 是 有 源 阵列 TFT LCD, 其 中 每 个 像素 都 由 3 个 晶体 管 驱动 和 
控制 ( 红 、 绿 、 蓝 ), 因 此 可 以 精确 地 控制 每 一 个 像素 ,获得 高 质量 的 图 像 。 


2. LCD 的 技术 指标 


由 于 显示 原理 与 传统 CRT 显示 咒 的 根本 不 同 ,因此 CRT 显示 器 的 耗 电大 体积 大 、 有 
辐射 有 闪烁 等 弊端 在 LCD 上 将 不 复 存在 ,LCD 的 技术 指标 也 有 一 些 变化 。 

(1) 像素 间距 

LCD 的 像素 间距 类 似 于 CRT 显示 需 的 点 距 , 但 LCD 的 像素 间距 对 于 产品 性 能 的 重要 
性 远 没有 CRT 的 点 距 那 么 高 。 因 为 LCD 的 像素 数量 是 固定 的 ,在 尺 二 与 分 辨 率 都 相同 的 
情况 下 ,大 多 数 LCD 的 像素 间距 基本 相同 ,主流 的 LCD 像素 间距 在 0. 3mm 左右 。 

(2) 分 辩 率 

由 于 LCD 的 像素 间距 固定 ,所 以 分 辨 率 不 能 任意 调整 。LCD 只 有 在 最 佳 分 辨 率 下 , 才 
能 显现 出 最 佳 影像 。 要 确定 一 款 显 示 咒 的 最 佳 分 辨 率 ,单单 根据 显示 器 的 尺寸 是 无 法 确定 
的 ,需要 综合 考虑 屏 侨 比例 、 屏 谷 尺 寸 及 物理 像 率 才能 确定 出 最 佳 分 辨 率 , 而 且 显 卡 的 性 能 
也 决定 着 可 设置 分 状 率 的 设置 范围 。 目 前 , 常 见 的 显示 器 屏幕 比例 (长 : 宽 ) 有 4 种 :5 : 4、 
4:3.16: 10 和 16: 9。 例如 ,4 : 3 对 应 的 分 辨 素 有 1024X768,5 : 4 对 应 的 分 辨 率 有 1280 XX 
1024,16 : 9 对 应 的 分 辩 率 有 1920X1080 等 。 更 大 尺寸 拥有 更 大 的 最 佳 分 辨 率 。 在 呈现 其 
他 的 分 辨 率 显 示 模 式 时 只 能 以 扩展 或 压缩 的 方式 将 画面 显示 出 来 ,显示 效果 将 受到 影响 。 

(3) 可 视角 度 

可 视角 度 是 指 人 们 清晰 观察 显示 屏幕 的 范围 ,这 是 LCD 的 一 个 重要 的 指标 ,因为 LCD 
从 侧面 观看 时 ,亮度 对比度 都 会 有 明显 的 下 降 。 可 视角 度 参 数 可 用 水 平 ( 左 右 ) 垂直 ( 上 
下 ) 来 衡量 ,也 可 以 用 左 / 右 、 上 /下 分 别 来 衡量 。 

(4) 亮度 

由 于 LCD 是 被 动 式 发 光 , 因 此 在 亮度 对比度 方面 的 指标 可 能 不 如 主动 发 光 的 CRT 显 
示 需 。LCD 的 亮度 取决 于 LCD 的 结构 和 背景 照明 的 类 型 。 亮 度 的 测量 单位 通 稼 为 坎 德 拉 
每 平方 米 (cd/m2 ) ,LCD 的 亮度 普遍 在 200 一 500cd/mz 。 

(5) 对 比 度 

对 比 度 实 际 上 就 是 亮度 的 比值 , 即 白 色 画 面 ( 最 亮 时 ) 下 的 亮度 除 以 黑色 画面 (最 暗 时 ) 
下 的 亮度 。 在 合理 的 亮度 值 下 ,对 比 度 越 高 ,其 所 能 显示 的 色彩 层次 越 丰富 。 传 统 的 对 比 度 
又 称 为 静态 对 比 度 ,现在 主流 的 显示 需 静 态 对 比 度 一 般 为 1000 : 1 一 1500 : 1。 动 态 对 比 度 
就 是 在 原 有 基础 上 加 进 了 一 个 自动 调整 显示 亮度 的 功能 ,这 样 就 将 原 有 对 比 度 提高 了 几 售 
甚至 几 十 倍 ,但 本 质 上 真正 的 对 比 度 没 有 改变 ,所 以 画面 细节 并 不 会 显示 得 更 清晰 ,但 因为 
它 的 自动 调节 亮度 的 功能 而 在 很 多 游戏 中 会 有 比较 好 的 表现 。 
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(6) 啊 应 时 间 

啊 应 时 间 反 映 了 液晶 显示 器 各 像素 点 对 输入 信号 反应 的 速度 , 即 每 个 像素 由 暗 转 亮 或 
由 亮 转 瞳 所 需要 的 时 间 。 啊 应 时 间 一 般 被 分 为 上 升 时 间 和 下 降 时 间 , 而 表示 时 应 以 两 者 之 
和 为 准 。 从 早期 的 25ms 到 目前 的 几 毫 秒 , 甚 至 lms, 响 应 时 间 在 不 断 地 缩短 , 啊 应 时 间 越 
短 则 使 用 者 在 看 动态 画面 时 越 不 会 有 尾 影 拖 电 的 感觉 。 

(7) 色彩 数 

色彩 数 就 是 屏幕 上 最 多 显示 多 少 种 颜色 的 总 数 。 目 前 ,LCD 的 液晶 板 有 8 位 和 6 位 两 
种 ,前 者 由 红 绿 蓝 三 原色 每 种 颜色 8 位 色彩 组 成 ,组 合 起 来 就 是 24 位 真 彩色 ,这 种 LCD 的 
颜色 一 般 标 称 为 16.7M; 后 者 三 原色 每 种 只 有 6 位 色彩 ,液晶 板 通过 “抖动 ?技术 ,局 部 快速 
切换 相近 颜色 ,利用 人 有 眼 的 残留 效应 获得 缺失 色彩 ,这 种 LCD 的 颜色 一 般 标 称 为 16. 2M。 
这 是 因为 抖动 技术 不 能 获得 完整 的 256 色 效 果 ,通常 只 有 253 色 ,3 个 253 相 乘 就 是 16. 2M 
色 。 不 过 两 者 实际 视觉 效果 差别 不 算 太 大 ,目前 高 端 LCD 以 16.7M 色 占 主流 。 


8.10.6 视频 显示 标准 


PC 系列 微机 的 显示 系统 由 显示 器 和 显示 适配器 (显卡 ) 构 成 ,显示 器 和 显卡 必须 配套 
使 用 。 下 面 介绍 PC 系列 微机 的 几 种 显示 标准 。 


1. MDA 


MDA(Monochrome Display Adapter) 属 于 单 色 显示 适 配 需 ,是 IBM 最 早 研 制 的 视频 显 
示 适 配器 。MDA 支持 80 列 、25 行 字 符 显 示 , 采 用 9X14 点 阵 的 字符 窗口 ,对 应 的 分 辩 率 为 
720X350。MDA 的 字符 显示 质量 高 ,但 是 不 文 持 图 形 功能 ,也 无 彩色 显示 能 力 。 


2. CGA 


在 MDA 推出 的 同时 ,IBM 也 推出 了 彩色 图 形 适 配 需 (Color Graphics Adapter,CGA) 。 
CGA 文 持 字符 、 图 形 两 种 方式 ,在 字符 方式 下 又 有 80 列 .25 行 和 40 列 、25 行 两 种 分 辨 率 ， 
但 字符 窗口 只 有 8X8 点 阵 , 故 字 符 质量 较 差 。 在 图 形 方式 下 ,有 640X200 和 320X200 两 
种 分 辩 率 ,在 最 高 分 辩 率 的 图 形 显示 方式 下 的 颜色 数 可 达 4 种 。 


3. EGA 


增强 的 图 形 适 配 需 (Enhanced Graphics Adapter,EGA) 是 IBM 公司 推出 的 第 二 代 图 形 
显示 适 配 带 , 它 莱 容 了 MDA 和 CGA 全 部 功能 。EGA 的 显示 分 辨 率 达 到 640 X350 ,字符 
显示 窗口 为 8X14 点 阵 , 使 字符 显示 质量 大 大 优 于 CGA 而 接近 于 MDA。 在 最 高 分 辨 率 的 
图 形 显 示 方 式 下 的 颜色 数 可 达 16 种 。 


4. VGA 


视频 图 形 阵 列 (Video Graphics Array,VGA) 是 IBM 公司 推出 的 第 三 代 图 形 显示 适 配 
顷 , 它 莱 容 了 MDA、CGA 和 EGA 的 全 部 功能 。VGA 的 显示 分 辨 率 为 640 X480, 可 显示 
256 种 颜色 。 近 年 来 又 出 现 了 超级 VGA(SVGA)。 在 VGA 中 ,显示 颜色 由 D/A 转换 的 输 
出 位 数 和 调 色 板 的 位 数 决定 。 其 标准 是 : 红 、 绿 、 蓝 每 一 路 视频 信号 均 采 用 6 位 D/A 转换 ， 
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并 使 用 18 位 的 彩色 调 色 板 , 因 此 最 多 可 以 组 合 出 2 二 256K 种 颜色 。 但 是 ,每 次 可 以 同时 
显示 的 颜色 数 还 取决 于 每 个 像素 在 VRAM 中 的 位 数 。 在 分 辩 率 为 640X480 时 ,每 个 像素 
对 应 4 位 信息 ,因此 可 以 从 256K 种 颜色 中 选择 16 种 颜色 ;在 分 辨 率 为 320X200 时 ,每 个 像 
素 对 应 8 位 信息 ,可 以 从 256K 种 颜色 中 选择 256 种 颜色 。VGA 的 字符 显示 功能 也 比 EGA 
有 所 改进 ,字符 窗口 为 9X16 点 阵 。 


S$. TVGA 


TVGA 是 美国 Trident Microsys Tems 公司 开发 的 超级 VGA 标准 ,与 VGA 完全 菲 
容 。 分 辨 率 有 640 X480、800 X600、1024X768、1280X1024 等 ,可 显示 的 颜色 数 有 16 色 、 
256 色 .64K 色 和 116M 色 等 。 


0. XGA 


XGA(eXtended Graphics Array) 是 IBM 公司 继 VGA 之 后 推出 的 扩展 图 形 阵列 显示 
标准 。 其 中 的 配置 有 协 处 理 需 ,属于 智能 型 适 配 需 。XGA 可 实现 VGA 的 全 部 功能 ,但 运 
行 速度 比 VGA 快 。 


8.10.7 微型 计算 机 的 显示 适配器 
1. 独立 显卡 和 集成 显卡 


显示 适 配 带 俗称 显卡 ,是 微机 中 进行 数 模 信 号 转换 的 设备 ,承担 输出 显示 图 形 的 任务 。 
显卡 接 在 主板 上 , 它 将 微机 的 数字 信号 转换 成 模拟 信号 让 显示 副 显 示 出 来 ,同时 显卡 还 有 图 
像 处 理 能 力 ,可 协助 CPU 工作 ,提高 整体 的 运行 速度 。 目 前 ,台式 微型 计算 机 有 两 类 显卡 
可 供 选 择 : 独立 显卡 和 集成 显卡 。 

独立 显卡 上 有 目 己 的 显示 核心 世 片 (GPU) 和 显存 ,不 占用 CPU 和 主 存 , 其 优点 是 处 理 
数据 速度 快 , 缺 点 是 功 耗 比较 高 , 且 需 要 额外 投资 购买 显卡 。 

集成 显卡 是 指 世 片 组 内 集成 了 显示 核心 必 片 ,使 用 这 种 芯片 组 的 主板 可 以 在 不 需要 独 
立 显卡 的 情况 下 实现 普通 的 显示 功能 。 集 成 的 显卡 不 市 显存 ,使 用 系统 的 一 部 分 主 存 作为 
显存 ,具体 的 容量 可 以 由 系统 根据 需要 目 动 动态 调整 。 显 然 , 如 果 使 用 集成 显卡 运行 需要 大 
量 占用 显存 的 程序 ,对 整个 系统 的 影响 会 比较 明显 ,此 外 ,由 于 系统 主 存 的 频率 通 常 比 独 立 
显卡 上 显存 的 频率 低 很 多 ,因此 集成 显卡 的 性 能 比 独 立 显 卡 要 差 。 


2. 显卡 性 能 三 要 素 


在 决定 显卡 性 能 的 三 要 素 中 ,首先 是 其 所 采用 的 显示 芯片 ,其 次 是 显存 带宽 (这 取决 于 
显存 位 宽 和 显存 频率 ) ,最 后 才 是 显存 容量 。 显 示 芯 片 指 的 是 提供 显示 功能 的 芯片 , 即 图 形 
处 理 硕 (GPU)。 显 存 位 宽 是 显存 在 一 个 时 钟 周期 内 所 能 传送 数据 的 位 数 , 位 数 武大 则 相同 
频率 下 所 能 传输 的 数据 量 越 大 ,目前 的 显存 位 宽 至 少 为 64b ,高 端的 可 达到 2048b 甚至 更 
高 。 显 存 容量 的 大 小 决定 着 显存 临时 存储 数据 的 能 力 , 早 期 显存 容量 的 只 有 512KB, 目 前 
市 面 上 的 显存 容量 已 达到 1GB 以 上 ,甚至 已 有 24GB 显存 的 显卡 了 。 显 存 容量 曾经 是 影响 
最 大 分 辩 率 的 一 个 瓶颈 ,但 目前 早已 经 不 再 是 影响 最 大 分 辨 率 的 因素 。 一 款 显 卡 究竟 应 该 
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配备 多 大 的 显存 容量 才 合 适 是 由 其 所 采用 的 显示 芯片 所 决定 的 ,也 就 是 说 显存 容量 应 该 与 
显示 核心 的 性 能 相 匹 配 才 合理 ,显示 必 片 性 能 越 高 ,其 所 配备 的 显存 容量 相应 也 应 该 越 大 ， 
而 低 性 能 的 显示 芯片 配备 大 容量 显存 对 其 性 能 是 没有 任何 帮助 的 。 

现在 决定 最 大 分 辨 率 的 其 实 是 显卡 的 RAMDAC(Random Access Memory Digital 
Analog Convertor) 频率 ,RAMDAC 即 随机 存 取 内 存 数字 -模拟 转换 费 , 它 的 作用 是 将 显存 
中 的 数字 信号 转换 为 显示 器 能 够 显示 出 来 的 模拟 信号 ,其 转换 速率 以 MHz 表示 。 该 数值 
决定 了 在 足够 的 显存 下 ,显卡 最 高 文 持 的 分 状 率 和 刷新 率 。 如 果 要 在 1024X768 的 分 辨 率 
下 达到 85Hz 的 刷新 率 ,RAMDAC 的 速率 至 少 是 1024X768X85HzX1.344( 折 算 系 数 ) 守 
90MHz。 目 前 ,主流 显卡 的 RAMDAC 能 达到 了 350MHz 和 400MHz, 已 足以 满足 和 超过 
目前 大 多 数 显 示 需 所 能 提供 的 分 辨 率 和 刷新 率 。 
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8-1 外 部 设备 有 哪些 主要 功能 ? 可 以 分 为 哪些 大 类 ? 各 类 中 有 哪些 典型 设备 ? 

8-2 分别 用 RZ、NRZ、NRZ-1、PE、FM、MFM 和 MEFM 制 记录 方式 记录 下 述 数 据 序列 , 画 出 写 电流 
波形 。 

(1) 1101110001100 

(2) 1010110011000 

8-3 ” 若 对 磁 介 质 存 储 器 写 人 数据 序列 10011 , 画 出 不 归 零 -1 制 . 调 相 制 、. 调 频 制 和 改进 的 调频 制 等 记 
录 方 式 的 写 电 流 波形 。 

8-4 主 存储 器 与 磁 介 质 存 储 器 在 工作 速度 方面 的 指标 有 什么 不 同 ? 为 什么 磁盘 存储 器 采用 两 个 以 
上 的 指标 来 说 明 其 工作 速度 ? 

8-5 某 磁盘 组 有 6 片 磁 盘 , 每 片 可 有 两 个 记录 面 ,存储 区 域内 径 为 22cm, 外 径 为 33cm, 道 密度 40 道 / 
厘米 ,位 密度 400b/cm, 转 速 2400r/min。 问 : 

(1) 共有 多 少 个 存储 面 可 用 ? 

(2) 共有 多 少 个 圆柱 面 ? 

(3) 整个 磁盘 组 的 总 存储 容量 有 多 少 ? 

(4) 数据 传送 率 是 多 少 ? 

(5) 如 果 某 文件 长 度 超过 一 个 磁道 的 容量 ,应 将 它 记 录 在 同一 存储 面 上 还 是 记录 在 同一 圆柱 面 上 ? 为 
什么 ? 

(6) 如 果 采 用 定 长 信息 块 记 录 格 式 ,直接 寻 址 的 最 小 单位 是 什么 ? 寻 址 命令 中 如 何 表示 磁盘 地 址 ? 

8-6 某 磁 盘存 储 器 的 转速 为 3000r/min, 共 有 4 个 盘面 ,5 道 /mm, 每 道 记 录 信 息 12 288B, 最 小 磁道 直 
径 为 230mm, 共 有 275 道 。 问 : 

(1) 该 磁盘 存储 器 的 存储 容量 是 多 少 ? 

(2) 最 高 位 密度 和 最 低位 密度 是 多 少 ? 

(3) 磁盘 的 数据 传送 率 是 多 少 ? 

(4) 平均 等 待 时 间 是 多 少 ? 

8-7 假定 某 磁盘 的 转速 是 12 000r/min, 平 均 寻 道 时 间 为 6ms, 传 输 速率 为 50MB/s, 有 关 控 制 器 的 开 
销 是 1ms, 请 计算 出 连续 地 读 写 256 个 扇 区 (每 一 扇 区 大 小 为 512B) 所 需要 的 平均 时 间 ( 忽 略 扇 区 间 可 能 有 
的 间隔 )。 

8-8 某 磁盘 组 有 效 盘 面 20 个 ,每 个 盘面 上 有 800 个 磁道 。 每 个 磁道 上 的 有 效 记 忆 容 量 为 13 000B, 块 
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间 阳 235B, 旋 转速 度 3000r/min。 问 : 

(1) 在 该 磁盘 存储 器 中 , 若 以 1000B 为 一 个 记录 ,这 样 ,一 个 磁道 能 存放 10 个 记录 。 若 要 存放 12 万 个 
记录 ,需要 多 少 个 圆柱 面 ( 一 个 记录 不 允许 跨越 多 个 磁道 )? 

(2) 该 磁盘 存储 器 的 平均 等 待 时 间 是 多 少 ? 

(3) 数据 传送 率 是 多 少 ? 

8-9 某 磁 盘 格式 化 为 24 个 扇 区 和 20 条 磁道 。 该 盘 能 按 需 要 选择 顺 时 针 或 逆 时 针 旋 转 , 旋 转 一 圈 的 
时 间 为 360ms, 读 一 块 数据 的 时 间 为 ms。 该 片上 有 3 个 文件 : 文件 A 从 磁道 6、 扇 区 1 开始 占有 两 块 ; 文 
件 也 从 磁道 2、. 扇 区 5 开始 占有 5 块 ;文件 C 从 磁道 5、 遍 区 3 开始 占有 3 块 。 

问 : 该 磁盘 的 平均 等 待 时 间 为 多 少 ? 平均 寻 道 时 间 是 多 少 ? 车 磁头 移动 和 磁盘 转动 不 同时 进行 , 且 磁 
头 的 初始 位 置 在 磁道 0、 扇 区 0, 按 顺序 C、B、A 读 出 上 述 3 个 文件 ,总 时 间 是 多 少 ? 在 相同 的 初始 位 置 情况 
下 , 读 出 上 述 3 个 文件 的 最 短 时 间 是 多 少 ? 此 时 文件 的 读 出 次 序 应 当 怎样 排列 ? 

8-10 ”什么 是 光盘 ? 简 述 光盘 的 工作 原理 。 

8-11 键盘 属于 什么 设备 ? 它 有 哪些 类 型 ? 如 何 消除 键 开 关 的 抖动 ? 简 述 非 编 码 键盘 查询 键 位 置 码 
的 过 程 。 

8-12 针 式 打印 和 字模 式 打印 有 何不 同 ? 各 有 什么 优 缺 点 ? 

8-13 什么 是 分 辨 率 ? 什么 是 灰 度 级 ? 它们 各 有 什么 作用 ? 

8-14 某 字 符 显 示 器 ,采用 7X9% 点 阵 方 式 , 每 行 可 显示 60 个 字符 ,缓存 容量 至 少 为 1260B, 并 采用 
7 位 标准 编码 , 问 : 

(1) 如 改 用 5X7 字符 点 阵 , 其 缓存 容量 为 多 少 ?( 设 行距 、 字 距 不 变 一 一 行距 为 5, 字 距 为 1) 

(2) 如 果 最 多 可 显示 128 种 字符 ,上 述 两 种 显示 方式 各 需 多 大 容量 的 字符 发 生 器 ROM? 

8-15 某 CRT 显示 器 可 显示 64 种 ASCII 字符 ,每 帧 可 显示 64 列 X25 行 ,每 个 字符 点 阵 为 7X8, 即 横 
向 7 点 , 字 间 间隔 1 点 ,纵向 8 点, 排 间 间隔 6 点 , 场 频 50Hz, 采 用 逐 行 扫描 方式 。 问 : 

(1) 缓存 容量 有 多 大 ? 

(2) 字符 发 生 器 (ROM) 容 量 有 和 多大? 

(3) 缓存 中 存放 的 是 字符 的 ASCII 码 还 是 字符 的 点 阵 信息 ? 

(4) 缓存 地 址 与 屏幕 显示 位 置 如 何 对 应 ? 

(5) 设置 哪些 计数 器 以 控制 缓存 访问 与 屏幕 扫描 之 间 的 同步 ? 它们 的 分 频 关 系 如 何 ? 

8-16 某 CRT 字 符 显 示 器 ,每 帧 可 显示 80 列 X20 行 ,每 个 字符 是 7X9 点 阵 ,字符 窗口 9X14, 场 频 为 
50Hz。 问 ; 

(1) 缓存 采用 什么 存储 器 ,其 中 存放 的 内 容 是 什么 ? 容量 应 为 多 大 ? 

(2) 缓存 地 址 如 何 安排 ? 铬 在 243 号 单元 存放 的 内 容 要 显示 出 来 ,其 屏幕 上 X 和 YY 的 坐标 应 是 多 少 ? 

(3) 字符 点 阵 存放 在 何 处 ? 如 何 读 出 显示 ? 

(4) 计算 出 主 振 频 率 以 及 点 计数 器 、 字 计数 器 \ 行 计数 器 、 排 计数 器 的 分 频频 率 。 

8-17 若 用 CRT 作 图 形 显示 器 ,其 分 辨 率 为 640 X200, 沿 横向 每 8 点 的 信息 存放 在 缓存 中 , 场 频 为 
60Hz。 问 : 

(1) 缓存 的 基本 容量 是 多 少 ? 

(2) 地 址 如 何 安排 ? 

(3) 点 计数 器 、. 字 节 计 数 器 、 行 计数 器 各 为 多 少 分 频 ? 

(4) 它 和 字符 显示 器 有 哪些 不 同 ? 

8-18 ” 某 字 符 显 示 器 分 辨 率 为 40 列 X25 行 ,字符 点 阵 5X7, 横 回 间 隔 2 点 , 排 间 间隔 4 点 , 问 : 缓存 
VRAM 容量 至 少 应 多 大 ? 应 设置 哪 几 级 同步 计数 器 ? 它们 的 分 频 关 系 如 何 ? 若 要 求 场 频 60Hz, 则 点 频 应 
为 多 少 ? 何 时 访问 一 次 VRAM? 地 址 如 何 确定 ? 

8-19 某 图 形 显示 器 的 分 辨 率 为 800X600, 耕 作 单 色 显 示 且 不 要 求 灰 度 等 级 , 则 VRAM 容量 至 少 应 
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多 大 ?应 设置 哪 几 级 同步 计数 器 ? 它们 的 分 频 关系 如 何 ? 若 要 求 场 频 60Hz, 则 点 频 应 为 多 少 ? 何 时 访问 | 一 

一 次 VRAM? 地 址 如 何 确定 ? 
8-20” 某 图 形 显示 器 的 分 辨 率 为 640X 480, 刷 新 频率 为 50Hz, 且 假定 水 平 回 扫 期 和 垂直 回 扫 期 各 占 。 于 

水 平 扫 描 周 期 和 垂直 扫描 周期 的 20%, 试 计算 图 形 显示 器 的 行 频 、 水 平 扫描 周期 、 每 个 像素 的 读 出 时 间 和 | 

视频 带宽 。 若 分 辩 率 提高 到 1024X768, 刷 新 频率 提高 到 60Hz, 再 次 计算 图 形 显示 器 的 行 频 、 水 平 扫描 周 

期 每 个 像素 的 读 出 时 间 和 视频 带宽 。 


8-21 ”水平 扫 描 频 率 ( 行 频 ) 的 单位 为 kHz, 垂直 扫描 频率 ( 场 频 ) 的 单位 为 Hz, 两 者 为 何 相 差 1000 倍 ? 


第 草 
9 输入 输出 系统 


计算 机 的 输入 输出 系统 是 整个 计算 机 系统 中 最 具有 多 样 性 和 复杂 性 的 部 分 ,本 章 首先 
介绍 主机 与 外 设 之 间 的 连接 问题 ,接着 重点 介绍 程序 查询 方式 、 程 序 中 断 方式 .DMA 方式 
和 通道 方式 4 种 输入 输出 控制 方式 。 


9.1 主机 与 外 设 的 连接 
现代 计算 机 系统 中 外 部 设备 的 种 类 繁多 ,各 类 外 部 设备 不 仅 结构 和 工作 原理 不 同 ,而 且 
与 主机 的 连接 方式 也 是 复杂 多 变 的 。 
9.1.1 输入 输出 接口 


主机 和 外 设 的 连接 方式 有 辆 射 型 连接 ,总线 型 连接 等 。 输 入 输出 接口 (IO 接口 ) 是 主 
机 和 外 设 之 间 的 交接 界面 ,通过 接口 可 以 实现 主机 和 外 设 之 间 的 信息 交换 。 

主机 和 外 设 之 间 进 行 信息 交换 为 什么 一 定 要 通过 接口 呢 ? 这 是 因为 主机 和 外 设 各 目 具 
有 上 自己 的 工作 特点 ,它们 在 信息 形式 和 工作 速度 上 具有 很 大 的 差异 ,接口 正 是 为 了 解决 这 些 
差异 而 设置 的 。 下 面 首先 分 析 主 机 和 外 设 之 间 需 要 交换 的 信息 。 

1. 数据 信息 


这 类 信息 可 以 是 通过 输入 设备 送 到 计算 机 的 输入 数据 ,也 可 以 是 经 过 计算 机 运算 处 理 
和 加 工 后 , 送 到 输出 设备 的 结果 数据 。 传 送 可 以 是 并 行 的 ,也 可 以 是 串 行 的 。 


2. 控制 信息 


这 类 信息 是 CPU 对 外 设 的 控制 或 管理 命令 ,例如 外 设 的 启动 和 停止 控制 .输入 或 输出 
操作 的 指定 、 工 作 方 式 的 选择 、 中 断 功 能 的 允许 和 禁止 等 。 


3. 状态 信息 


这 类 信息 用 来 标志 外 设 的 工作 状态 ,例如 输入 设备 数据 准备 好 标志 、 输 出 设备 忙 、 亲 标 
志 等 。CPU 在 必要 时 可 通过 对 它 的 查询 来 决定 下 一 步 的 操作 。 
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4. 联络 信息 


这 类 信息 是 主机 和 外 设 间 工作 的 时 间 配 合 信 息 , 通 过 联络 信息 可 以 决定 不 同 工 作 速 度 
的 外 设 和 主机 之 间 交 换 信 息 的 最 佳 时 刻 , 以 保证 整个 计算 机 系统 能 统一 协调 地 工作 。 


5. 外 设 识别 信息 


这 类 信息 是 W/O 寻 址 的 信息 ,使 CPU 能 从 众多 的 外 设 中 寻找 出 与 目 己 进行 信息 交换 
的 唯一 的 设备 。 


9.1.2 接口 的 功能 和 基本 组 成 
1. 接口 的 功能 


(1) 实现 主机 和 外 设 的 通信 联络 控制 

接口 中 的 同步 控制 电路 用 来 解决 主机 与 外 设 的 时 间 配 合 问题 。 

(2) 进行 地 址 译 码 和 设备 选择 

当 CPU 送 来 选择 外 设 的 地 址 码 后 ,接口 必须 对 地 址 进行 译 码 以 产生 设备 选择 信息 ,使 
主机 能 和 指定 外 设 交 换 信 息 。 

(3) 实现 数据 缓冲 

数据 缓冲 寄存 器 用 于 数据 的 暂 存 ,以 避免 丢失 数据 。 在 传送 过 程 中 , 先 将 数据 送 入 数据 
缓冲 寄存 器 中 ,然后 再 送 到 输出 设备 或 主机 中 。 

(4) 数据 格式 的 变换 

为 了 满足 主机 或 外 设 的 各 上 自 要 求 ,接口 电路 中 必须 具有 各 类 数据 相互 转换 的 功能 。 例 
如 ,并 - 串 转换 、 串 -并 转换 、 模 - 数 转换 、 数 - 模 转 换 以 及 二 进 制 数 和 ASCII 码 的 相互 转换 等 。 

(5) 传递 控制 命令 和 状态 信息 

当 CPU 要 局 动 菜 一 外 设 时 ,通过 接口 中 的 命令 寄存 硕 癌 外 设 发 出 局 动 命 令 ; 当 外 设 准 
备 就 绪 时 , 则 有 “准备 好 ”状态 信息 送 回 接口 中 的 状态 寄存 右 , 为 CPU 提供 外 设 已 经 具备 与 
主机 交换 数据 条 件 的 反馈 信息 。 当 外 设 向 CPU 提出 中 断 请 求 或 DMA 请 求 时 ,CPU 也 应 
有 相应 的 啊 应 信号 反馈 给 外 设 。 


2. 接口 的 基本 组 成 


如 上 所 述 ,接口 中 要 分 别传 送 数 据 信 息 、 控 制 信息 和 状态 信息 ,这 些 信 息 都 是 通过 数据 
总 线 来 传送 。 大 多 数 计算 机 都 把 外 部 设备 的 状态 信息 视 为 输入 数据 ,而 把 控制 信息 看 成 输 
出 数据 ,并 在 接口 中 分 设 各 自 相 应 的 寄存 絮 ,赋予 不 同 的 端口 地 址 ,各 种 信息 分 时 地 使 用 数 
据 总 线 传送 到 各 自 的 寄存 器 中 。 接 口 的 基本 组 成 及 与 主机 、 外 设 间 的 连接 如 图 9-1 所 示 。 

接口 (Interface) 与 端口 (Port) 是 两 个 不 同 的 概念 。 端 口 是 指 接口 电 路 中 可 以 被 CPU 
直接 访问 的 寄存 器 ,若干 个 端口 加 上 相应 的 控制 逻辑 电路 才 组 成 接口 。 

通常 ,一 个 接口 中 包含 数据 端口 .命令 端口 和 状态 端口 。 存 放 数 据 信息 ee 
据 端口 ,存放 控制 命令 的 寄存 带 称 为 命令 端口 ,存放 状态 信息 的 寄存 器 称 为 状态 并 
CPU 通过 输入 指令 可 以 从 有 关 端 口中 读 取 信息 ,通过 输出 指令 可 以 把 信 plete 丁当 


接口 


外 设 识别 
| 
数据 或 命令 或 状态 | | 涩 近 (并 /里 


地 址 信息 


控制 联络 信息 院 制 由 区 控制 联络 


9-1 接口 与 主机 、 外 设 间 的 连接 


CPU 对 不 同 端口 的 操作 有 所 不 同 , 有 的 端口 只 能 写 或 只 能 读 , 有 的 端口 既 可 以 读 又 可 以 写 。 
例如 ,对 状态 端口 只 能 读 , 将 外 设 的 状态 标志 送 到 CPU 中 ;对 命令 端口 只 能 写 ,将 CPU 的 
各 种 控制 命令 发 送 给 外 设 。 为 了 节省 硬件 ,在 有 的 接口 电路 中 ,状态 信息 和 控制 信息 可 以 共 
用 一 个 寄存 器 (端口 ) , 称 为 设备 的 控制 /状态 寄存 器 。 


3. 接口 的 类 型 


输入 输出 接口 的 分 类 可 以 从 不 同 的 角度 来 考虑 。 

(1) 按 数 据 传 送 方 式 分 类 

输入 输出 接口 有 串 行 接口 和 并 行 接口 。 这 里 所 说 的 数据 传送 方式 指 的 是 外 设 和 接口 一 
侧 的 传送 方式 ,而 在 主机 和 接口 一 侧 数据 总 是 并 行 传送 的 ,如 图 9-1 所 示 。 在 并 行 接口 中 ， 
外 设 和 接口 间 的 传送 宽度 是 一 个 字 节 (或 字 ) 的 所 有 位 ,一 次 传输 的 信息 量 大 ,但 数据 线 的 数 
目 将 随 着 传送 数据 宽度 的 增加 而 增加 。 在 串 行 接口 中 ,外 设 和 接口 间 的 数据 是 一 位 接 一 位 
地 串 行 传送 的 ,一 次 传输 的 信息 量 小 ,但 只 需 一 根 数据 线 。 在 远程 终端 和 计算 机 网 络 等 设备 
离 主 机 较 远 的 场合 下 ,用 串 行 接口 比较 经 济 合算 。 

(2) 按 主 机 访问 W/O 设备 的 控制 方式 分 类 

输入 输出 接口 可 分 为 程序 查询 式 接口 、 程 序 中 断 接口 .DMA 接口 ,以 及 更 复杂 一 些 的 
通道 控制 大 等 。 

(3) 按 功能 选择 的 灵活 性 分 类 

输入 输出 接口 有 可 编程 接口 和 不 可 编程 接口 。 可 编程 接口 的 功能 及 操作 方式 是 由 程序 
来 改变 或 选择 的 ,用 编程 的 手段 可 使 一 块 接口 芯片 执行 多 种 不 同 的 功能 。 不 可 编程 接口 则 
不 能 由 程序 来 改变 其 功能 ,只 能 用 硬 连 线 逻辑 来 实现 不 同 的 功能 。 

(4) 按 通用 性 分 类 

输入 输出 接口 有 通用 接口 和 专用 接口 。 通 用 接口 是 可 供 多 种 外 设 使 用 的 标准 接口 , 通 
用 性 强 。 专 用 接口 是 为 某 类 外 设 或 某 种 用 途 专 门 设计 的 。 

(5) 按 输入 输出 的 信号 分 类 

输入 输出 接口 有 数字 接口 和 模拟 接口 。 数 字 接 口 的 输入 输出 全 为 数字 信号 ,以 上 列举 
的 并 行 接口 和 串 行 接口 都 是 数字 接口 。 而 模 数 转换 器 和 数 模 转换 髓 属于 模拟 接口 。 

(6) 按 应 用 来 分 类 

输入 输出 接口 分 为 以 下 几 种 : 

@ 运行 辅助 接口 。 运 行 辅助 接口 是 计算 机 日 常 工作 所 必需 的 接口 器 件 ,包括 数据 总 
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线 、 地 址 总 线 和 控制 总 线 的 驱动 器 和 接收 器 、 时 钟 电 路 、 磁 盘 接 口 及 磁带 接口 。 

@ 用 户 交 互 接 口 。 这 类 接口 包括 计算 机 终端 接口 、 键 盘 接口 .图 形 显 示 需 接口 及 语音 
识别 与 合成 接口 等 。 

@) 传 感 接口 。 包 括 温度 传 感 接口 、 压 力 传 感 接口 和 流量 传 感 接 口 等 。 

@ 控制 接口 。 这 类 接口 用 于 计算 机 控制 系统 。 


9.1.3 外 设 的 识别 与 端口 村 址 


为 了 能 在 众多 的 外 设 中 寻找 或 挑选 出 要 与 主机 进行 信息 交换 的 外 设 , 就 必须 对 外 设 进 
行 编 址 。 外 设 识别 是 通过 地 址 总 线 和 接口 电路 中 的 外 设 识别 电路 来 实现 的 ,1/O 端口 地 址 
就 是 主机 与 外 设 直接 通信 的 地 址 ,CPU 可 以 通过 端口 发 送 命令 、 读 取 状 态 和 传送 数据 。 如 
何 实现 对 这 些 端口 的 访问 ,这 就 是 所 谓 的 I/O 端口 的 编 址 方式 。 


1. 端口 地 址 编 址 方式 


1/O 端口 编 址 方式 有 两 种 : 一 种 是 I/O 映射 方式 , 即 把 1/O 端口 地 址 与 存储 需 地 址 分 
别 进行 独立 的 编 址 ; 另 一 种 是 存储 器 映射 方式 , 即 把 端口 地 址 与 存储 器 地 址 统一 编 址 。 这 个 
问题 已 在 第 3 草 中 作 过 介绍 ,这 里 则 从 外 设 识别 的 角度 加 以 进一步 讨论 。 

(1) 独立 编 址 

在 这 种 编 址 方式 中 , 主 存 地 址 空间 和 1/O 端口 地 址 空间 是 相对 独立 的 ,分 别 单独 编 址 。 
例如 ,在 8086 中 ,其 主 存 地 址 范围 是 从 00000H 到 FFFFFH, 其 1/O 端口 地 址 范围 是 从 
0000H 到 FFFFH ,它们 互相 独立 , 互 不 影响 。CPU 访问 主 存 时 ,由 主 存 读 写 控制 线 控制 ; 访 
问 外 设 时 ,由 IO 读 写 控制 线 控制 ,所 以 在 指令 系统 中 必须 设置 专门 的 1/O 指令 。 当 CPU 
使 用 1/O 指令 时 ,其 指令 的 地 址 字段 直接 或 间接 的 指示 出 端口 地 址 。 这 些 端口 地 址 被 接口 
电路 中 的 地 址 译 码 带 接 收 并 且 进 行 译 码 ,符合 者 就 是 CPU 所 指定 的 外 设 寄存 带 , 该 外 设 寄 
存 器 将 被 CPU 访问 。 

(2) 统一 编 址 

在 这 种 编 址 方式 中 ,1/O 端口 地 址 和 主 存单 元 地 址 是 统一 编 址 的 ,把 I/O 接口 中 的 端口 
作为 主 存单 元 一 样 进行 访问 ,不 设置 专门 的 1/O 指令 。 当 CPU 访问 外 设 时 ,把 分 配给 该 外 
设 的 地 址 码 ( 具 体 到 该 外 设 接口 中 的 某 一 寄存 器 号 ) 送 到 地 址 总 线 上 ,然后 各 外 设 接口 中 的 
地 址 译 码 器 对 地 址 码 进 行 译 码 ,如 果 符 合 即 是 CPU 指定 的 外 设 寄存 器。 

例如 ,PDP-11 机 分 配给 某 些 外 设 寄存 器 的 端口 地 址 如 下 。 


纸 市 输入 机 控制 状态 寄存 需 177550Q 
数据 缓冲 寄存 需 177552Q 
穿孔 输入 机 : 控制 状态 寄存 天 177554Q 


数据 缓冲 寄存 需 177556Q 
控制 台 打 字 机 : 键盘 控制 状态 寄存 器 177560Q 


键盘 数据 寄存 大 177562Q 
打印 控制 状态 寄存 器 。” 177564Q 
打印 数据 寄存 天 177566Q 


行 式 打 印 机 .: 控制 状态 寄存 天 177514Q 
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数据 缓冲 寄存 天 177516Q 


磁盘 存储 大 : 盘 驱 动 硕 寄存 大 177400Q 
错误 寄存 大 177402Q 
控制 状态 寄存 器 177404Q 
字 计 数 寄 存 需 177406Q 
主 存 地 址 寄存 需 177410Q 


盘 数 据 地 址 寄存 需 177412Q 
数据 缓冲 寄存 硕 177414Q 
从 这 个 例子 可 以 看 出 ,每 个 外 设 至 少 有 两 个 寄存 带 : 控制 状态 寄存 器 和 数据 缓冲 寄存 
器 ,外 设 寄存 器 的 端口 地 址 是 连续 的 (PDP-11 按 字 节 编 址 ,外 设 寄存 器 字 长 16 位 )。 在 
PDP-11 中 ,把 主 存 的 高 4KB 地 址 空间 留 给 外 设 寄 存 器 和 CPU 内 部 寄存 器 使 用 ,这 4KB 存 
储 空 间 不 允许 用 户 再 存放 其 他 内 容 。 


2. 独立 编 址 方式 的 端口 访问 


独立 编 址 方式 广泛 应 用 于 Intel 系列 微型 计算 机 及 大 型 计算 机 中 ,Intel 80x86 的 IO 
地 址 空间 由 64K(2”) 个 独立 编 址 的 8 位 端口 组 成 。 两 个 连续 的 8 位 端口 可 作为 16 位 端口 
处 理 ;4 个 连续 的 8 位 端口 可 作为 32 位 端口 处 理 。 

80x86 的 专用 I/O 指令 IN 和 OUT 有 下 接 寻 址 和 间接 寻 址 两 种 类 型 。 直 接 寻 址 IO 
端口 的 寻 址 范围 为 00 一 FFH ,至 多 为 256 个 端口 地 址 。 这 时 程序 可 以 指定 : 

编号 0 一 255 的 256 个 8 位 端口 ; 

编号 0、2、4、…、252、254 的 128 个 16 位 端口 ; 

编号 0、4、8、…、248、252 的 64 个 32 位 端口 。 

间接 寻 址 由 DX 寄存 器 间接 给 出 I/O 端口 地 址 。DX 寄存 器 长 16 位 ,所 以 最 多 可 寻 址 
2 一 64K 个 端口 地 址 ,这 时 程序 可 指定 : 

编号 0 一 65 535 的 65 536 个 8 位 端口 ; 

编号 0、2、4、…、65 532、65 534 的 32 768 个 16 位 端口 ; 

编号 0、4、8、…、65 528、65 532 的 16 384 个 32 位 端口 。 

CPU 一 次 可 实现 字 节 (8 位 )、 字 (16 位 ) 或 双 字 (32 位 ) 的 数据 传送 。32 位 端口 应 对 准 
可 被 4 整除 的 地 址 ;16 位 端口 应 对 准 偶 地 址 。 


9.1.4 输入 输出 信息 传送 控制 方式 


主机 和 外 设 之 间 的 信息 传送 控制 方式 ,经 历 了 由 低级 到 高 级 、 由 简单 到 复杂 、 由 集中 管 
理 到 各 部 件 分 散 管 理 的 发 展 过 程 , 按 其 发 展 的 先后 次 序 和 主机 与 外 设 并 行 工 作 的 程度 ,可 以 
分 为 程序 查询 方式 程序 中 断 方式 、 和 直接 存储 右 存 取 方 式 和 1/O 通道 控制 方式 4 种 。 


1. 程序 查询 方式 


程序 查询 方式 是 一 种 程序 直接 控制 方式 ,这 是 主机 与 外 设 之 间 进 行 信息 交换 的 最 简单 
方式 ,输入 和 输出 完全 是 通过 CPU 执行 程序 来 完成 的 。 一 旦 某 一 外 设 被 选中 并 局 动 之 后 ， 
主机 将 查询 这 个 外 设 的 茶 些 状态 位 ,看 其 是 否 准备 就 绪 ? 在外 设 未 准备 就 绪 , 主 机 将 再 次 查 
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询 ; 右 外 设 已 准备 就 绪 , 则 执行 一 次 IO 操作 。 

这 种 方式 控制 简单 ,但 外 设 和 主机 不 能 同时 工作 ,各 外 设 之 间 也 不 能 同时 工作 ,系统 效 
率 很 低 , 因 此 , 仅 适 用 于 外 设 的 数目 不 多 .对 I/O 处 理 的 实时 要 求 不 那么 高 ,CPU 的 操作 任 
务 比 较 单 一 且 并 不 很 忙 的 情况 。 


2. 程序 中 断 方式 


在 主机 局 动 外 设 后 ,无 须 等 待 查询 ,而 是 继续 执行 原来 的 程序 ,外 设 在 做 好 输入 输出 准 
备 时 , 回 主 机 发 中 断 请 求 , 主 机 接 到 请 求 后 就 暂时 中 止 原 来 执行 的 程序 , 转 去 执行 中 断 服务 
程序 对 外 部 请 求 进行 处 理 ,在 中 断 处 理 完 毕 后 返回 原来 的 程序 继续 执行 。 显 然 ,程序 中 断 不 
仅 适 用 于 外 部 设备 的 输入 输出 操作 ,也 适用 于 对 外 界 发 生 的 随机 事件 的 处 理 。 

程序 中 断 在 信息 交换 方式 中 处 于 最 重要 的 地 位 , 它 不 仅 允 许 主机 和 外 设 同 时 并 行 工作 ， 
并 且 人 允许 多 个 外 设 同 时 工作 。 但 是 ,完成 一 次 程序 中 断 还 需要 许多 辅助 操作 , 当 外 设 数 目 较 
多 时 ,中 断 请 求 过 分 频 紧 ,可 能 使 CPU 应 接 不 上 暇 ; 男 外 ,对 于 一 些 高 速 外 设 , 由 于 信息 交换 
是 成 批 的 ,如 果 处 理 不 及 时 ,可 能 会 造成 信息 丢失 ,因此 , 它 主要 适用 于 中 低速 外 设 。 


3. 直接 存储 器 存 取 (DMA) 方 式 


DMA 方式 是 在 主 存 和 外 设 之 间 开 辟 直 接 的 数据 通路 ,可 以 进行 基本 上 不 需要 CPU 介 
入 的 主 存 和 外 设 之 间 的 信息 传送 ,这 样 不 仅 能 保证 CPU 的 高 效率 ,而 且 能 满足 高 速 外 设 的 

DMA 方式 只 能 进行 简单 的 数据 传送 操作 ,在 数据 块 传送 的 起 始 和 结束 时 还 需 CPU 及 
中 断 系 统 进行 预 处 理 和 后 处 理 。 


4. 1/O 通道 控制 方式 


LI/O 通道 控制 方式 是 DMA 方式 的 进一步 发 展 ,在 系统 中 设 有 通道 控制 部 件 , 每 个 通道 
挂 磊 干 外 设 。 主 机 执行 IO 指令 局 动 有 关 通 道 ,通关 执行 通过 程序 ,完成 输入 输出 操作 。 

通道 是 一 个 具有 特殊 功能 的 处 理 需 , 它 能 独立 地 执行 通道 程序 ,产生 相应 的 控制 信号 ， 
实现 对 外 设 的 统一 管理 和 外 设 与 主 存 之 间 的 数据 传送 。 但 它 不 是 一 个 完全 独立 的 处 理 天 。 
它 要 在 CPU 的 1/O 指令 指挥 下 才能 局 动 、 停 止 或 改变 工作 状态 ,是 从 属于 CPU 的 一 个 专 
用 处 理 硕 。 

一 个 通道 执行 输入 输出 过 程 全 部 由 通道 按照 通道 程序 日 行 处 理 ,不 论 交 换 信 息 多 少 , 只 
打扰 CPU 两 次 (局 动 和 停止 时 )。 因 此 ,主机 、 外 设 和 通道 可 以 并 行 同时 工作 ,而 且 一 个 通 
道 可 以 控制 多 人 台 不 同类 型 的 设备 。 

目前 ,小 型 和 微型 计算 机 大 多 采用 程序 查询 方式 、 程 序 中 断 方式 和 DMA 方式 ;大 型 和 
中 型 计算 机 多 采用 通道 方式 。 


9.2 程序 查 询 万 式 及 其 接口 


程序 查询 方式 是 主机 与 外 设 之 间 进 行 信息 交换 的 最 简单 方式 ,程序 查询 方式 的 核心 问 
题 在 于 需要 不 断 地 查询 IO 设备 是 否 准 备 就 绪 。 


SE 
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9.2.1 程序 查询 方式 


1. 程序 查询 的 基本 思想 


由 CPU 执行 一 段 输入 输出 程序 来 实现 主机 与 外 设 之 间 数 据 传 送 的 方式 称 为 程序 直接 
控制 方式 。 根 据 外 设 的 不 同性 质 , 这 种 传送 方式 又 可 分 为 无 条 件 传 送 和 程序 查询 方式 两 种 。 

在 无 条 件 传送 方式 中 ,IO 端口 总 是 准备 好 接收 主机 的 输出 数据 ,或 总 是 准备 好 回 主 机 输 
入 数据 ,因而 CPU 无 须 查 询 外 设 的 工作 状态 ,而 默认 外 设 始终 处 于 准备 就 绪 状 态 。 在 CPU 认 
为 需要 时 ,随时 可 直接 利用 IO 指令 访问 相应 的 IO 端口 ,实现 与 外 设 之 间 的 数据 交换 。 这 种 
方式 的 优点 是 软 、 人 硬件 结构 都 很 简单 ,但 要 求 时 序 配合 精确 ,一 般 的 外 设 难以 满足 要 求 。 所 以 ， 
只 能 用 于 简单 开关 量 的 输入 输出 控制 中 , 稍 复杂 一 点 的 外 设 都 不 采用 此 种 方式 。 

许多 外 设 的 工作 状态 是 很 难事 先 预知 的 ,例如 , 何 时 按键 ,打印 机 是 否 能 接收 新 的 打印 
输出 信息 等 。 当 CPU 与 外 设 工作 不 同步 时 ,很 难 确保 CPU 在 执行 输入 操作 时 ,外 设 一 定 
是 “准备 好 ”的 ;而 在 执行 输出 操作 时 ,外 设 一 定 是 缓冲 硕 空 "的 。 为 了 保证 数据 传送 的 正确 
进行 ,就 要 求 CPU 在 程序 中 查询 外 设 的 工作 状态 。 如 果 外 设 尚 未 准备 就 绪 ,CPU 就 循环 等 
待 ,只 有 当 外 设 已 做 好 准备 ,CPU 才能 执行 IO 指令 进行 数据 传送 ,这 就 是 程序 查询 方式 。 


2. 程序 查询 方式 的 工作 流程 


程序 查询 方式 的 工作 过 程 如 下 : 

@ 预 置 传送 参数 。 在 传送 数据 之 前 ,由 CPU 执行 一 段 初始 化 程序 , 预 置 传送 参数 。 传 送 
参数 包括 存 取 数据 的 主 存 缓冲 区 首 地 址 和 传送 数据 的 个 数 。 

@@ 回 外 设 接口 发 出 命令 字 。 当 CPU 选中 某 台 外 设 时 ， 
执行 输出 指令 回 外 设 接 口 发 出 命令 字 局 动 外 设 ,为 接收 数据 
或 发 送 数据 做 应 有 的 操作 准备 。 

@ 从 外 设 接口 取 回 状态 字 。CPU 执行 输入 指令 ,从 外 设 
接口 中 取 回 状态 字 并 进行 测试 ,判断 数据 传送 是 否 可 以 进行 。 

由 查询 外 设 标 志 。CPU 不 断 查询 状态 标志 。 如 果 外 设 
没有 准备 就 绪 ,CPU 就 踏步 等 待 , 转 至 第 邹 步 ,一 直到 这 个 
外 设 准备 就 绪 , 并 发 出 “外 设 准 备 就 绪 ? 信 和 号 为 止 。 

@) 传送 数据 。 只 有 外 设 准 备 好 ,才能 实现 主机 与 外 设 
间 的 一 次 数据 传送 。 输 入 时 ,CPU 执行 输入 指令 ,从 外 设 接 
口 的 数据 缓冲 寄存 需 中 接收 数据 ;输出 时 ,CPU 执行 输出 指 
令 ,将 数据 写 人 外 设 接口 的 数据 缓冲 寄存 器 中 。 

@ 修改 传送 参数 。 每 进行 一 次 数据 传送 之 后 必须 要 修改 
传送 参数 ,其 中 包括 主 存 缓冲 区 地 址 加 1, 传 送 个 数 计数 器 减 1。 

G@ 判断 传送 是 否 结束 。 如 果 传 送 个 数 计 数 器 不 为 0, 则 
转 第 包 步 ,继续 传送 ,直到 传送 个 数 计数 需 为 0, 表示 传送 
结束 。 

程序 查询 方式 的 工作 流程 如 图 9-2 所 示 , 其 程序 查询 的 9-2 程序 查询 方式 流程 图 
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核心 如 图 中 虚线 框 部 分 ,真正 传送 数据 的 操作 由 输入 或 输出 指令 完成 。 
9.2.2 程序 查询 方式 接口 

程序 查询 方式 是 最 简单 .经济 的 1/O 方式 ,只 需 很 少 的 硬件 。 通 常 接口 中 至 少 有 两 个 
寄存 器 ,一 个 是 数据 缓冲 寄存 器 , 即 数据 端口 ,用 来 存放 与 CPU 进行 传送 的 数据 信息 ; 另 一 
个 是 供 CPU 查询 的 设备 状态 寄存 器 , 即 状态 端口 ,这 个 寄存 器 由 多 个 标志 位 组 成 ,其 中 最 
重要 的 是 “外 设 准备 就 绪 > 标 志 ( 输 入 或 输出 设备 的 准备 就 绪 标志 可 以 不 是 同一 位 )。 当 
CPU 得 到 这 位 标志 后 就 进行 判断 ,以 决定 下 一 步 是 继续 循环 等 待 还 是 进行 1/O 传送 。 也 有 
些 计算 机 仅 设置 状态 标志 触发 器 ,其 作用 与 设备 状态 寄存 器 相同 。 


1. 输入 接口 


图 9-3 为 查询 式 输入 接口 电路 ,图 中 Ready 为 准备 好 触发 器 , 它 对 应 于 设备 状态 寄存 器 
的 Du 位 。 


9-3 查询 式 输入 接口 电路 


在 输入 设备 准备 好 数据 时 ,发 出 一 个 选 通信 号 (STB) ,将 数据 送 入 锁 存 需 , 同 时 将 
Ready 触发 硕 置 “1”, 以 表示 接口 电路 中 已 有 数据 ( 即 准备 就 结 )。CPU 要 从 外 设 输入 数据 
时 , 先 执行 输入 指令 读 取 状态 字 , 如 Ready 王 1, 再 执行 输入 指令 从 锁 存 需 中 读 取 数 据 , 同 时 
把 Ready 触发 需 清 "0”, 以 准备 从 外 设 接收 下 一 个 数据 ;如 Ready 一 0, 则 踏步 等 待 ,继续 读 取 
状态 字 ,直至 Ready 二 1 为 止 。 


2. 输出 接口 


图 9-4 为 查询 式 输 出 接口 电路 ,图 中 Busy 为 人 触发 希 , 对 应 于 设备 状态 寄存 天 的 
D; 位 。 

输出 时 ,CPU 首先 执行 输入 指令 读 取 状态 字 , 如 果 Busy 王 1, 则 表示 接口 的 输出 锁 存 大 
是 满 的 ,CPU 只 能 踏步 等 待 ,继续 读 取 状态 字 ,直至 Busy=0 为 止 ; 如 果 Busy 二 0, 则 表示 接 
口 的 输出 锁 存 器 是 空 的 ,允许 CPU 向 外 设 发 送 数 据 。 此 时 ,CPU 执行 输出 指令 ,将 数据 送 
入 锁 存 器 ,并 将 Busy 触发 器 置 “1”。 当 输出 设备 把 CPU 送 来 的 数据 真正 输出 之 后 ,将 发 出 
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9-4 查询 式 输出 接口 电路 


一 个 ACK 信 号 ,使 Busy 触发 器 置 “0”, 以 准备 下 一 次 传送 。 

奋 有 多 个 外 设 需要 用 查询 方式 工作 时 ,其 工作 流程 如 图 9-5 所 示 。 此 时 ,CPU 巡回 
检测 各 个 外 设 ,逐个 进行 查询 ,发 现 哪 个 外 设 准备 就 绪 , 就 对 该 外 设 实施 数据 传送 ,然后 
再 对 下 一 外 设 查 询 , 依 次 循环 。 在 整个 查询 过 程 中 ,CPU 不 能 做 别 的 事 。 如 果菜 一 外 设 
刚好 在 查询 过 目 己 之 后 才 处 于 就 绪 状 态 ,那么 它 就 必须 等 CPU 查询 完 其 他 外 设 后 再 次 查 
询 自 己 时 ,才能 等 到 CPU 为 它 服务 ,这 对 于 实时 性 要 求 较 高 的 外 设 来 说 ,就 可 能 丢失 
数据 。 


[号 外 设 准备 就 绪 ? 对 1 号 外 设 服务 
2 号 外 设 准备 就 绪 ? i 对 2 号 外 设 服务 
3 号 外 设 准备 就 绪 5 一 对 3 号 外 设 服务 


7 号 外 设 准 备 就 绪 ? 一 对 n 号 外 设 服务 


9-5 多 个 外 设 的 查询 工作 流程 
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9.3 ”中断 系 统 和 程序 中 断 方式 


中 断 是 现代 计算 机 有 效 合理 地 发 挥 效能 和 提高 效率 的 一 个 十 分 重要 的 功能 。CPU 中 
通常 设 有 处 理 中 断 的 机 构 一 一 中 断 系 统 ,以 解决 各 种 中 断 的 共性 问题 。 本 节 主 要 分 析 中 断 
系统 的 功能 ,特别 强调 IO 中 断 。 


9.3.1 中 断 的 基本 概 会 
1. 中 断 的 提出 


程序 查询 方式 虽然 简单 ,但 却 存 在 着 下 列 明显 的 缺点 : 

在 查询 过 程 中 ,CPU 长 期 处 于 踏步 等 待 状态 ,使 系统 效率 大 大 降低 。 

GO CPU 在 一 段 时 间 内 只 能 和 一 台 外 设 交 换 信息 ,其 他 设备 不 能 同时 工作 。 

G@) 不 能 发 现 和 处 理 预 先 无 法 信 计 的 错误 和 异常 情况 。 

为 了 提高 输入 输出 能 力 和 CPU 的 效率 ,20 世纪 50 年 代 中 期 ,程序 中 断 方式 被 引进 计 
算 机 系统 。 程 序 中 断 方式 的 思想 是 : CPU 在 程序 中 安排 好 在 某 一 时 刻 局 动 茶 一 台 外 设 , 然 
后 CPU 继续 执行 原来 程序 ,不 需要 像 查 询 方式 那样 一 直 等 竺 外 设 的 准备 就 绪 状 态 。 一 且 
外 设 完 成 数据 传送 的 准备 工作 (输入 设备 的 数据 准备 好 或 输出 设备 的 数据 缓冲 融 空 ) 时 , 便 
主动 向 CPU 发 出 一 个 中 断 请 求 , 请 求 CPU 为 自己 服务 。 在 可 以 啊 应 中 断 的 条 件 下 ,CPU 
暂时 中 止 正在 执行 的 程序 , 转 去 执行 中 断 服务 程序 为 中 断 请 求 者 服务 ,在 中 断 服务 程序 中 完 
成 一 次 主机 与 外 设 之 间 的 数据 传送 ,传送 完成 后 ,CPU 仍 返 回 原来 的 程序 ,从 断 点 处 继续 执 
行 。 图 9-6 给 出 了 程序 中 断 方式 的 示意 图 。 


工作 ”完成 工作 ”完成 
外 部 设备 1 
| 


其 | | = 
EE | 
中 断 服务 程序 ， 请 请 | 
CPU | "| ] | 返 求 | |! | 返 
口 | 口 
现行 程序 _L__ + tO 
局 动 WRY WRY 


9-6 ”程序 中 断 方式 


从 图 9-6 中 可 以 看 到 ,中 断 方 式 在 一 定 程度 上 实现 了 CPU 和 外 设 的 并 行 工作 ,使 CPU 
的 效率 得 到 充分 的 发 挥 。 不 仅 如 此 ,由 于 中 断 的 引入 ,还 能 使 多 个 外 设 并 行 工 作 ,CPU 根据 
需要 可 以 启动 多 个 外 设 , 被 启动 的 外 设 分 别 同 时 独立 地 工作 ,一 旦 外 设 准 备 就 绪 , 即 可 问 
CPU 发 出 中 断 请 求 ,CPU 可 以 根据 预先 安排 好 的 优先 顺序 , 按 轻 重 缓急 处 理 外 设 与 自己 的 
数据 传送 。 另 外 ,计算 机 在 运行 过 程 中 可 能 会 发 生 预 料 不 到 的 异常 事件 ,如 运算 错 、 掉 电 ` 海 
出 等 ,由 于 中 断 的 引入 ,使 计算 机 可 以 捕捉 到 这 些 故障 和 错误 ,及 时 予以 处 理 。 所 以 ,现代 计 
算 机 无 论 是 巨型 机 、 大 型 机 、 小 型 机 还 是 微型 机 都 具有 中 断 处 理 的 能 力 。 

从 图 9-6 中 还 可 以 看 到 ,中 断 的 处 理 过 程 实际 上 是 程序 的 切换 过 程 , 即 从 现行 程序 切换 
到 中 断 服务 程序 ,再 从 中 断 服务 程序 返回 到 现行 程序 。CPU 每 次 执行 中 断 服 务 程序 前 总 要 


问世 于 半 。 
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保护 断 点 \ 保 护 现场 ,执行 完 中 断 服务 程序 返回 现行 程序 之 前 又 要 恢复 现场 、 恢 复 断 点 。 这 
些 中 断 的 辅助 操作 都 将 会 限制 数据 传送 的 速度 。 

中 断 系 统 是 计算 机 实现 中 断 功 能 的 软 、 人 鲁 件 总 称 。 一 般 在 CPU 中 配置 中 断 机 构 ,在 外 
设 接口 中 配置 中 断 控 制 融 ,在 软件 上 设计 相应 的 中 断 服务 程序 。 


2. 程序 中 断 与 调用 子 程序 的 区 别 


程序 中 断 是 指 计算 机 执行 现行 程序 的 过 程 中 ,出 现 某 些 急需 处 理 的 异常 情况 和 特殊 请 
求 ,CPU 暂时 中 止 现 行程 序 , 而 转 去 对 随机 发 生 的 更 紧迫 的 事件 进行 处 理 , 在 处 理 完毕 后 ， 
CPU 将 自动 返回 原来 的 程序 继续 执行 。 

从 表面 上 看 起 来 ,计算 机 的 中 断 处 理 过 程 有 点 类 似 于 调用 子 程序 的 过 程 ,这 里 现行 程序 
相当 于 主 程序 ,中 断 服务 程序 相当 于 子 程序 。 但 是 ,它们 之 间 却 有 着 本 质 上 的 区 别 ,主要 的 
区 别 在 于 : 

Q@ 子 程序 的 执行 是 由 程序 员 事先 安排 好 的 (由 一 条 调用 子 程序 指令 转 人 ) ,而 中 断 服 务 
程序 的 执行 则 是 由 随机 的 中 断 事件 引起 的 。 

GO 子 程序 的 执行 受到 主 程序 或 上 层 子 程序 的 控制 ,而 中 断 服务 程序 一 般 与 被 中 断 的 现 
行程 序 毫 无 关系 。 

@ 不 存在 同时 调用 多 个 子 程序 的 情况 ,而 有 可 能 发 生 多 个 外 设 同 时 请 求 CPU 为 自己 
服务 的 情况 。 

因此 ,中 断 的 处 理 要 比 调用 子 程序 指令 的 执行 复杂 得 多 。 


3. 中 断 的 基本 类 型 


(1) 日 愿 中 断 和 强迫 中 断 

自愿 中 断 又 称 程序 自 中 断 , 它 不 是 随机 产生 的 中 断 ,而 是 在 程序 中 安排 的 有 关 指 令 , 这 
些 指令 可 以 使 机 器 进入 中 断 处 理 的 过 程 , 如 80x86 指令 系统 中 的 软 中 断 指令 INT n。 

强迫 中 断 是 随机 产生 的 中 断 , 不 是 程序 中 事先 安排 好 的 。 当 这 种 中 断 产 生 后 ,由 中 断 系 
统 强 迫 计 算 机 中 止 现行 程序 并 转 入 中 断 服务 程序 。 

(2) 程序 中 断 和 简单 中 断 

程序 中 断 就 是 前 面 提 到 的 中 断 ,主机 在 响应 中 断 请 求 后 ,通过 执行 一 段 中 断 服务 程序 来 
处 理 更 紧迫 的 任务 ,这 样 的 中 断 处 理 过 程 将 在 后 面 详 细 讨 论 , 它 需 要 占用 一 定 的 CPU 
时 间 。 

简单 中 断 就 是 外 设 与 主 存 之 间 直 接 进行 信息 交换 的 方法 , 即 DMA 方式 。 这 种 中 断 不 
去 执行 中 断 服务 程序 , 故 不 破坏 现行 程序 的 状态 。 主 机 发 现 有 简单 中 断 请 求 ( 即 DMA 请 
求 ) 时 ,让 出 一 个 或 几 个 存 取 周期 供 外 设 与 主 存 交 换 信 息 , 然 后 继续 执行 程序 。 简 单 中 断 是 
早期 对 DMA 方式 的 一 种 叫 法 ,为 避免 误解 ,现在 一 般 很 少 使 用 这 个 名 词 。 

(3) 内 中 断 和 外 中 断 

内 中 断 是 指 由 于 CPU 内 部 硬件 或 软件 原因 引起 的 中 断 , 如 单 步 中 断 .溢出 中 断 等 。 

外 中 断 是 指 CPU 以 外 的 部 件 引 起 的 中 断 。 通 常 ,外 中 断 又 可 以 分 为 不 可 屏蔽 中 断 和 
可 屏蔽 中 断 两 种 。 不 可 屏蔽 中 断 优 先 级 别 较 高 ,常用 于 应 急 处 理 , 如 掉 电 、 主 存 读 写 校 验 错 
等 ;而 可 屏蔽 中 断 级 别 较 低 ,常用 于 一 般 1/O 设备 的 数据 传送 。 


痊 入 输出 条 统 


(4) 癌 量 中 断 和 非 向 量 中 断 

向 量 中 断 是 指 那 些 中 断 服务 程序 的 入 口 地 址 是 由 中 断 事件 日 己 提供 的 中 断 。 中 断 事 件 
在 提出 中 断 请 求 的 同时 ,通过 人 硬件 向 主机 提供 中 断 服务 程序 入 口 地 址 , 即 向 量 地 址 。 

韭 向 量 中 断 的 中 断 事件 不 能 直接 提供 中 断 服务 程序 的 入 口 地 址 。 

(5) 单 重 中 断 和 多 重 中 断 

单 重 中 断 在 CPU 执行 中 断 服务 程序 的 过 程 中 不 能 再 被 打 断 。 

多 重 中 断 在 执行 某 个 中 断 服务 程序 的 过 程 中 ,CPU 可 去 啊 应 级 别 更 高 的 中 断 请 求 ,又 
称 为 中 断 舱 套 。 多 重 中 断 表征 计算 机 中 断 功 能 的 强 轮 ,有 的 计算 机 能 实现 8 级 以 上 的 多 重 
中 断 。 


9.3.2 中 断 请 求 和 中 新 判 优 
1. 中 断 源 和 中 断 请 求 信号 


中 断 源 是 指 中 断 请 求 的 来 源 , 即 引 起 计算 机 中 断 的 事件 。 通 党 ,一 台 计 算 机 允许 有 多 个 
中 断 源 。 由 于 每 个 中 断 源 向 CPU 发 出 中 断 请 求 的 时 间 是 随机 的 ,为 了 记录 中 断 事件 并 区 
分 不 同 的 中 断 源 ,可 采用 具有 存储 功能 的 触发 豆 来 记录 中 断 源 ,这 个 触发 硕 称 为 中 断 请 求 触 
发 大 (INTR)。 当 茶 一 个 中 断 源 有 中 断 请 求 时 ,其 相应 的 中 断 请 求 触 发 右 置 成 "1 状态 , 表 
示 该 中 断 源 向 CPU 提出 中 断 请 求 。 

中 断 请 求 触 发 妖 可 以 分 散在 各 个 中 断 源 中 ,也 可 以 集中 到 中 断 接口 电路 中 。 在 中 断 接 
口 电路 中 ,多 个 中 断 请 求 触发 融 构 成 一 个 中 断 请 求 寄 存 融 。 中 断 请 求 寄 存 帮 的 每 一 位 对 应 
一 个 中 断 源 , 其 内 容 称 为 中 断 字 或 中 断 码 。 中 断 字 中 为 1” 的 位 就 表示 对 应 的 中 断 源 有 中 断 

2. 中 断 请 求 信 号 的 传送 


(1) 独立 请 求 线 

每 个 中 断 源 单独 设置 中 断 请 求 线 ,将 中 断 请 求 信号 直接 送 往 CPU, 如 图 9-7(a) 所 示 。 
这 种 方式 的 特点 是 CPU 在 接 到 中 断 请 求 的 同时 也 就 知道 了 中 断 源 是 谁 ,其 中 断 服务 程序 
的 入 口 地 址 在 哪里 。 这 有 利于 实现 向 量 中 断 ,提高 中 断 的 响应 速度 ;但 是 其 硬件 代价 较 大 ， 
日 CPU 所 能 连接 的 中 断 请 求 线 的 数目 有 限 ,难以 扩充 。 

(2) 公共 请 求 线 

多 个 中 断 源 共有 一 根 公 共 请 求 线 ,如 图 9-7(b) 所 示 。 这 种 方式 的 特点 是 在 负载 允许 的 
情况 下 ,中 断 源 的 数目 可 随意 扩充 ;但 CPU 在 接 到 中 断 请 求 后 ,必须 通过 软件 或 硬件 的 方 
法 来 识别 中 断 源 ,然后 再 找 出 中 断 服 务 程序 的 入 口 地 址 。 

(3) 二 维 结构 

将 中 断 请 求 线 连 成 二 维 结构 , 如 图 9-7(c) 所 示 。 同 一 优先 级 别 的 中 断 源 , 采 用 一 根 公 共 
的 请 求 线 ;不 同 请 求 线 上 的 中 断 源 优先 级 别 不 同 。 这 种 方式 综合 了 前 两 种 方式 的 优点 ,在 中 
断 源 较 多 的 系统 中 常 采用 这 种 方式 。 


3. 中 断 优先 级 与 判 优 方法 
当 多 个 中 断 源 同时 发 出 中 断 请 求 时 ,CPU 在 任何 瞬间 只 能 接受 一 个 中 断 源 的 请 求 。 究 
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Uy EE 中 肠 源 | = … = | 中 电源 


CPU |INTA: | 中 断 源 加 中 断 源 ,.._ | 中 断 源 
2.1 2,2 2 


INTR,, 
m.,] 1,2 m.n 
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9-7 ”中断 请 求 信号 的 传送 


况 首 先 啊 应 哪 一 个 中 断 请 求 呢 ? 通常 ,把 全 部 中 断 源 按 中 断 的 性 质 和 处 理 的 轻重 缓急 安排 
优先 级 ,并 进行 排队 。 

确定 中 断 优 先 级 的 原则 是 ; 对 那些 提出 中 断 请 求 后 需要 立刻 处 理 , 否 则 就 会 造成 严重 
后 果 的 中 断 源 规定 为 最 高 的 优先 级 ;而 对 那些 可 以 延迟 响应 和 处 理 的 中 断 源 规定 为 较 低 的 
优先 级 。 例 如 ,故障 中 断 一 般 优先 级 较 高 ,其 次 是 简单 中 断 , 接 着 才 是 1/O 设备 中 断 。 

每 个 中 断 源 均 有 一 个 为 其 服务 的 中 断 服务 程序 ,每 个 中 断 服务 程序 都 有 与 之 对 应 的 优 
先 级 别 。 男 外 ,CPU 正在 执行 的 程序 也 有 优先 级 。 只 有 当 某 个 中 断 源 的 优先 级 别 高 于 
CPU 现在 的 优先 级 时 ,才能 中 止 CPU 执行 当前 的 程序 。 在 一 些 计 算 机 的 程序 状态 字 寄 存 
需 中 就 设置 了 优先 级 字段 ,如 PDP-11 机 。 

中 断 判 优 的 方法 可 分 为 软件 判 优 和 硬件 判 优 两 种 。 

(1) 软件 判 优 方法 

所 谓 软 件 判 优 方法 ,就 是 用 程序 来 判别 优先 级 ,这 是 最 简单 的 中 断 判 优 方法 。 图 9-8 给 
出 了 软件 判 优 的 流程 图 。 当 CPU 接 到 中 断 请 求 信 号 后 ,就 执行 查询 程序 ,逐个 检测 中 断 请 
求 寄存 器 的 各 位 状态 。 检 测 顺序 是 按 优先 级 的 大 小 排列 的 ,最 先 检测 的 中 断 源 具 有 最 高 的 
优先 级 ,其 次 检测 的 中 断 源 具 有 次 高 优先 级 ,如 此 下 去 ,最 后 检测 的 中 断 源 具 有 最 低 的 优 
先 级 。 


输入 输出 系统 


显然 ,软件 判 优 是 与 识别 中 断 源 结合 在 一 起 的 , 当 查 询 到 中 断 请 求 信 号 的 发 出 者 ,也 就 
是 找到 了 中 断 源 , 可 以 立即 转 入 对 应 的 中 断 服务 程序 中 去 。 

软件 判 优 方法 简单 ,可 以 灵活 地 修改 中 断 源 的 优先 级 别 ; 但 查询 、 判 优 完全 是 靠 程序 实 
现 的 ,不 但 占用 CPU 时 间 , 而 且 判 优 速度 慢 。 

(2) 硬件 判 优 电路 

采用 硬件 判 优 电路 实现 中 断 优 先 级 的 判定 可 节省 CPU 时 间 , 判 优 速度 快 , 但 是 成 本 
较 高 。 
根据 中 断 请 求 信 号 的 传送 方式 不 同 , 有 不 同 的 优先 排队 电路 ,常见 的 方案 有 : 独立 请 求 
线 的 优先 排队 电路 、 公 共 请 求 线 的 优先 排队 电路 等 。 这 些 排队 电路 的 共同 特点 是 : 优先 级 
别 高 的 中 断 请 求 将 自动 封锁 优先 级 别 低 的 中 断 请 求 。 人 硬件 排队 电路 一 旦 设计 连接 好 之 后 ， 
将 无 法 改变 其 优先 级 别 。 

独立 请 求 线 的 优先 排队 电路 如 图 9-9 所 示 ,图 中 INTR; 为 来 自 中 断 源 的 中 断 请 求 信 号 ， 
INTR; 为 经 过 优先 排队 电路 后 送 给 CPU 的 中 断 请 求 信 号 。 


对 1 号 中 断 源 服务 


< > 对 2 号 中 断 源 服 
对 


INTR， INTR。 INTR; 


N 
< > 对 7 号 中 断 源 服务 
N 


INTR' INTR。” INTR3 
图 9-8 软件 判 优 的 流程 图 图 9-9 独立 请 求 线 的 优先 排队 电路 


优先 级 别 从 高 到 低 依次 是 INTR INTR。 JINTR:… 优 先 级 别 高 的 中 断 请 求 将 自动 封 
锁 优 先 级 别 低 的 中 断 请 求 。 若 INTR; = 二 INTR; = 二 1 时 , 门 1 输出 的 低 电 平 将 自动 封锁 门 3、 
门 5……。 故 仅 有 INTR' 二 1, 其 他 的 INTR; 均 等 于 0。 

公共 请 求 线 的 优先 排队 电路 如 图 9-10 所 示 , 图 中 下 面 的 虚线 部 分 是 一 个 串 行 优先 链 。 
INTR,; 是 各 中 断 源 的 中 断 请 求 信 号 ,优先 级 别 从 高 到 低 依次 是 INTR， INTR。 、INTR;。 而 
INTP, INTP， ,INTP; 是 与 之 对 应 的 中 断 排队 选中 信号 。INTI 为 中 断 排 队 输 入 ,INTO 为 中 
断 排队 输出 。 若 没有 更 高 优先 级 的 中 断 请 求 (INTI 二 0) 时 ,INTP 二 1, 此 时 如 果 中 断 请 求 
INTRi 二 1, 当 CPU 发 来 中 断 响应 信号 INTA 时 ,INTRi 的 请 求 被 选中 ,选中 信号 经 门 7 送 
入 编码 电路 ,产生 一 个 唯一 对 应 的 向 量 地 址 。 另 一 方面 ,由 于 此 时 INTR; 二 0, 封 锁 门 2, 使 
INTP; INTP; 全 为 低 电 平 , 即 排队 识别 工作 不 再 向 下 进行 。 
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INTR， INTR。 INTR: 
9-10 公共 请 求 线 的 优先 链 排队 电路 


若 INTR, 无 请 求 , 则 INTR;,=0, 门 7 被 封锁 ,不 会 向 编码 电路 送 入 选中 信和 号 ;与 此 同 
时 , 因 INTRi 二 1, 经 门 2 和 门 3, 使 INTP; 二 1, 如 果 此 时 INTR:=1, 则 INTR; 被 选中 。 否 
则 , 串 行 优 先 链 继续 向 下 查询 ,直至 找到 发 出 中 断 请 求 信 号 INTR; 的 中 断 源 为 止 。 


9.3.3 中 新 响应 和 中 新 处 理 
1. CPU 响应 中 断 的 条 件 


CPU 响应 中 断 必 须 满 足下 列 条 件 。 

(1) CPU 接收 到 中 断 请 求 信号 

首先 中 断 源 要 发 出 中 断 请 求 , 同 时 CPU 还 要 接收 到 这 个 中 断 请 求 信 号 

(2) CPU 允许 中 断 

CPU 允许 中 断 , 即 开 中 断 。CPU 内 部 有 一 个 中 断 允 许 触 发 器 (EINT), 只 有 当 
EINT==1 时 ,CPU 才 可 以 啊 应 中 断 源 的 中 断 请 求 (中 断 允 许 ) ;如果 EINT==0,CPU 处 于 不 
允许 中 断 状态 ,即使 中 断 源 有 中 断 请 求 ,CPU 也 不 啊 应 (中 断 关 闭 )。 

通常 ,中 断 允许 触发 颖 由 开 中 断 指令 来 置 位 ,由 关中 断 指令 或 硬件 自动 使 其 复位 。 

(3) 一 条 指令 执行 完毕 

这 是 CPU 响应 中 断 请 求 的 时 间 限 制 条 件 。 一 般 情况 下 ,CPU 在 一 条 指令 执行 完毕 且 
没有 更 紧迫 的 任务 时 才能 啊 应 中 断 请 求 。 


2. 中 断 隐 指令 


CPU 响应 中 断 之 后 ,经 过 某 些 操作 , 转 去 执行 中 断 服务 程序 。 这 些 操 作 是 由 硬件 直接 
实现 的 ,把 它 称 为 中 断 隐 指 令 。 中 断 隐 指令 并 不 是 指令 系统 中 的 一 条 真正 的 指令 
作 码 ,所 以 中 断 隐 指令 是 一 种 不 允许 而 且 也 不 可 能 为 用 户 使 用 的 特殊 指令 。 中 断 隐 指令 
要 完成 以 下 操作 。 

(1) 保存 断 点 

为 了 保证 在 中 断 服务 程序 执行 完毕 能 正确 返回 原来 的 程序 ,必须 将 原来 程序 的 断 点 ( 即 
程序 计数 器 (PC) 的 内 容 ) 保 存 起 来 。 断 点 可 以 压 人 堆栈 ,也 可 以 存 人 主 存 的 特定 单元 中 。 

(2) 暂 不 允许 中 断 

暂 不 允许 中 断 即 关中 断 。 在 中 断 服务 程序 中 ,为 了 保护 中 断 现 场 ( 即 CPU 主要 寄存 关 
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的 内 容 ) 期 间 不 被 新 的 中 断 所 打 断 ,必须 要 关中 断 , 从 而 保证 被 中 断 的 程序 在 中 断 服务 程序 
执行 完毕 之 后 能 接着 正确 地 执行 下 去 。 

并 不 是 所 有 的 计算 机 都 在 中 断 隐 指令 中 由 硬件 自动 地 关中 断 ,也 有 些 计 算 机 的 这 一 操 
作 是 由 软件 (中 断 服务 程序 ) 来 实现 的 。 

(3) 引出 中 断 服务 程序 

引出 中 断 服务 程序 的 实质 就 是 取出 中 断 服务 程序 的 入 口 地 址 送 程 序 计数 器 (PC)。 对 
于 向 量 中 断 和 非 向 量 中 断 , 引 出 中 断 服 务 程序 的 方法 是 不 相同 的 。 


3. 中 断 周 期 


以 上 几 个 基本 操作 在 不 同 的 计算 机 系统 中 的 处 理 方 法 是 各 异 的 。 通 常 , 在 组 合 逻 辑 控 
制 的 计算 机 中 ,专门 设置 了 一 个 中 断 周期 来 完成 中 断 隐 指令 的 任务 。 在 微 程序 控制 的 计算 
机 中 , 则 专门 安排 有 一 段 微 程 序 来 完成 中 断 隐 指 令 的 这 些 操作 。 

假设 将 断 点 存 至 主 存 的 0 号 单元 , 且 采 用 硬件 问 量 中 断 法 寻找 中 断 服务 程序 的 入 口 地 
址 (向 量 地 址 一 中 断 服务 程序 的 入口 地 址 ) , 则 在 中 断 周期 需 完 成 如 下 操作 : 

QD 将 特定 地 址 “0” 送 至 存储 器 地 址 寄存 器 , 记 作 0 一 MAR。 

@ 将 PC 的 内 容 ( 断 点 ) 送 至 MDR , 记 作 (PC) 一 MDR。 

G@) 回 主 存 发 与 命令 ,局 动 存 储 需 进行 写 操 作 , 记 作 Write。 

@ 将 MDR 的 内 容 通过 数据 总 线 写 入 MAR 所 指示 的 主 存单 元 (0# ) 中 , 记 作 MDR 一 
MCMAR ) 。 

@ 癌 量 地 址 形成 部 件 的 输出 送 至 PC, 为 进入 中 断 服务 程序 作 准 备 , 记 作 问 量 地 址 习 PC。 

@ 关中 断 , 将 中 断 允许 触发 右 清 0, 记 作 0 一 EINT。 

如 果断 点 存 人 堆栈 ,只 须 将 上 述 虽 改 为 堆栈 指针 的 内 容 送 MAR, 记 作 (SP) 一 MAR.。 
当然 断 点 进 栈 ,同时 需要 修改 栈 指 针 。 


4. 进入 中 断 服务 程序 


识别 中 断 源 的 目的 在 于 使 CPU 转 入 为 该 中 断 源 专门 设置 的 中 断 服务 程序 。 解 决 这 个 
问题 的 方法 可 以 用 软件 ,也 可 以 用 硬件 ,或 用 两 者 相 结 合 的 方法 。 

软件 的 方法 前 面 已 经 提 到 ,由 中 断 隐 指令 控制 进入 一 个 中 断 总 服务 程序 ,在 那里 判 优 、 
寻找 中 断 源 并 且 转 入 相应 的 中 断 服务 程序 。 这 种 
方法 方便 \ 灵 活 ,硬件 极 简 单 ,但 效率 较 低 。 


下 面 着 重 讨 论 便 件 癌 量 中 断 法 。 当 CPU 啊 - 作 完 / 中 断 优先 级 
应 某 一 中 断 请 求 时 ,硬件 能 自动 形成 并 找 出 与 该 近 诸 求 站 


中 断 源 对 应 的 中 断 服务 程序 的 入口 地 址 。 

向 量 中 断 的 过 程 如 图 9-11 所 示 。 当 中 断 源 向 
CPU 发 出 中 断 请 求 信号 INTR 之 后 ,CPU 进行 一 
定 的 判 优 处 理 。 硅 决定 啊 应 这 个 中 断 请 求 , 则 向 /7 识别 中 断 源 YY 向 量 地 址 现场 处 理 
中 断 源 发 出 中 断 响应 信号 INTA。 中 断 源 接 到 \ 站 胞 地 址 
INTA 信和 号 后 就 通过 自己 的 向 量 地 址 形成 部 件 向 
CPU 发 送 向 量 地 址 ,CPU 接收 该 向 量 地 址 之 后 就 图 9-11 向 量 中 断 过 程 
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可 转 入 相应 的 中 断 服务 程序 。 

向 量 地 址 通常 有 以 下 两 种 情况 。 

(1) 回 量 地 址 是 中 断 服 务 程 序 的 入口 地 址 

如 果 疝 量 地 址 就 是 中 断 服务 程序 的 入 口 地 址 , 则 CPU 不 需要 再 经 过 处 理 就 可 以 进入 
相应 的 中 断 服务 程序 ,Z-80 的 中 断 方式 0 就 是 这 种 情况 。 各 中 断 源 在 接口 中 由 便 件 电 路 形 
成 一 条 含有 中 断 服务 程序 入 口 地 址 的 特殊 指令 (重新 启动 指令 ), 从 而 转 入 相应 的 中 断 服务 
程序 。 中 断 源 癌 CPU 提供 RST 指令 ,其 操作 码 为 11NNN111, 其 中 NNN 为 3 位 二 进 制 
码 ,范围 为 000 一 111, 故 RST 指 令 有 8 种 组 合 。 

RST 指令 完成 的 功能 如 下 : 

将 断 点 (PC 的 内 容 ) 压 人 堆栈 保存 。 

@ PC<-8XNNN( 向 量 地 址 ) 。 

由 此 可 见 ,RST 指令 能 调用 位 于 存储 器 前 64 个 字 节 的 8 个 中 断 服务 程序 中 的 任 
意 一 个 ,两 个 人 口 地 址 之 间 相 隔 有 8 个 单元 ,它们 依次 是 00H,08H,10H,…,38H。 如 
果 中 断 服务 程序 较 短 ,就 可 以 放 在 这 些 单元 里 ;如 果 中 断 服务 程序 较 长 ,可 在 这 8 个 单 
元 里 青 放 一 条 转移 指令 ,以 转 至 真正 的 中 断 服务 程序 中 去 。 例 如 , 当 指 令 为 RST7 时 ， 
经 CPU 处 理 后 得 到 的 向 量 地 址 VA=0038H, 即 该 中 断 源 的 中 断 服 务 程序 的 入 口 地 址 
为 0038H。 

(2) 回 量 地 址 是 中 断 癌 量 表 的 指针 

如 果 疝 量 地 址 是 中 断 向 量 表 的 指针 , 则 向 量 地 址 指向 一 个 中 断 向 量 表 ,从 中 断 向 量 表 的 
相应 单元 中 再 取出 中 断 服务 程序 的 入 口 地 址 ,此 时 中 断 源 给 出 的 向 量 地 址 是 中 断 服务 程序 
入 口 地 址 的 地 址 。 目 前 ,大 多 数 微 型 计算 机 都 采用 这 种 方法 ,Intel 8086 和 2-80 的 中 断 方式 
2 都 属于 这 种 情况 ,其 转 中 断 服务 程序 的 方法 如 图 9-12 所 示 。 


中 CPU 接口 
高 8 位 低 8 位 


中 断 入 口 地 址 1 
中 断 入 口 地 址 2 
中 断 和 人口 地 址 3 


中 断 服务 程序 1 
中 断 服务 程序 2 


图 9-12 2-80 的 中 断 方式 2 


nn 
| 


并 有 吧 


5. 中 断 现 场 的 保护 和 恢复 
中 断 现 场 指 的 是 发 生 中 断 时 CPU 的 主要 状态 ,其 中 最 重要 的 是 断 点 , 男 外 还 有 一 些 通 
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用 寄存 天 的 状态 。 之 所 以 需要 保护 和 恢复 现场 的 原因 是 因为 CPU 要 先后 执行 两 个 完全 不 
同 的 程序 (现行 程序 和 中 断 服务 程序 ) ,必须 进行 两 种 程序 运行 状态 的 转换 。 一 般 来 说 ,在 中 
断 隐 指 令 中 ,CPU 硬件 将 目 动 保存 断 点 ,有 些 计算 机 还 目 动 保存 程序 状态 字 寄 存 融 
(PSWR) 的 内 容 。 但 是 ,在 许多 应 用 中 ,要 保证 中 断 返 回 后 原来 的 程序 能 正确 地 继续 运行 ， 
仅 保存 这 一 两 个 寄存 副 的 内 容 是 不 够 的 。 为 此 ,在 中 断 服务 程序 开始 时 ,应 由 软件 去 保存 那 
些 人 硬件 没有 保存 ,而 在 中 断 服务 程序 中 又 可 能 用 到 的 寄存 豆 ( 如 有 某 些 通用 寄存 硕 ) 的 内 容 , 在 
中 断 返 回 之 前 ,这 些 内 容 还 应 该 被 恢复 。 

现场 的 保护 和 恢复 方法 不 外 乎 有 纯 软 件 和 软 、 硬 件 相 结合 两 种 。 纯 软件 方法 是 在 CPU 
啊 应 中 断后 ,用 一 系列 传送 指令 把 要 保存 的 现场 参数 传送 到 主 存 茶 些 单元 中 ,当中 断 服 务 程 
序 结束 后 ,再 采用 传送 指令 进行 相反 方向 的 传送 。 这 种 方法 不 需要 硬件 代价 ,但 是 占用 了 
CPU 的 宝贵 时 间 ,速度 较 慢 。 现 代 计 算 机 一 般 都 先 采 用 人 硬件 方法 来 自动 快速 的 保护 和 恢复 
部 分 重要 的 现场 ,其 余 寄 人 存 融 的 内 容 再 由 软件 完成 保护 和 恢复 ,这 种 方法 的 硬件 支持 是 
堆栈 。 

软 、 便 件 保护 现场 往往 是 和 回 量 中 断 结 合 在 一 起 使 用 的 。 首 先 把 断 点 和 程序 状态 字 目 
动 讨 人 堆栈 ,这 就 是 保护 旧 现 场 ;接着 根据 中 断 源 送 来 的 回 量 地 址 目 动 取出 中 断 服 务 程序 人 
口 地 址 和 新 的 程序 状态 字 ,这 就 是 建立 新 现场 ;最 后 由 一 些 指令 实现 对 必要 的 通用 寄存 大 的 
保护 。 恢 复 现 场 则 是 保护 现场 的 逆 处 理 。 


9.3.4 多 重 中 新 与 中 断 异 项 


1. 中 断 藤 套 

中 断 舱 套 过 程 如 图 9-13 所 示 。 中 断 艇 套 的 层次 可 以 有 多 层 , 越 在 里 层 的 中 断 请 求 越 
急迫 ,优先 级 越 高 ,因此 优先 得 到 CPU 的 服务 。 页 Eh 

要 使 计算 机 具有 多 重 中 断 的 能 力 , 首 先 要 能 保 断 断 


护 多 个 断 点 ,而 且 先 发 生 的 中 断 请 求 的 断 点 , 先 保护 

后 恢复 ;后 发 生 的 中 断 请 求 的 断 点 ,后 保护 先 恢复 。 

堆栈 的 先进 后 出 特点 正好 满足 多 重 中 断 这 一 先后 次 

序 的 需要 。 同 时 ,在 CPU 进入 菜 一 中 断 服务 程序 之 ,i 衣 
后 ,系统 必须 处 于 开 中 断 状态 ,否则 中 断 嵌 套 是 不 可 

能 实现 的 。 


和 震 暴 可 沿 


2. 人 允许 和 禁止 中 断 


允许 中 断 还 是 禁止 中 断 是 用 CPU 中 的 中 断 允 
许 触 发 大 控制 的 ,当中 断 允 许 触 发 大 (EINT) 被 置 
“1”, 则 允许 中 断 ;当中 断 允许 触发 右 (EINT) 被 置 “0”, 则 禁止 中 断 。 

允许 中 断 即 开 中 断 , 下 列 情况 应 开 中 断 : 

中 无 论 是 单 重 中 断 还 是 多 重 中 断 , 在 中 断 服务 程序 执行 完毕 ,恢复 中 断 现场 之 后 。 

@ 在 多 重 中 断 的 情况 下 ,保护 中 断 现场 之 后 。 


图 9-13 中断 若 套 
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禁止 中 断 即 关中 断 , 下 列 情况 应 关中 断 : 
QD 当 啊 应 某 一 级 中 断 请 求 , 不 再 允许 被 其 他 中 断 请 求 打 断 时 。 
多 在 中 断 服务 程序 的 保护 和 恢复 现场 之 前 。 


3. 中断 屏蔽 


中 断 源 发 出 中 断 请 求 之 后 ,这 个 中 断 请 求 并 不 一 定 能 真正 送 入 CPU ,在 有 些 情 况 下 ,可 
以 用 程序 方式 有 选择 地 封锁 部 分 中 断 ,这 就 是 中 断 屏蔽 。 

如 果 给 每 个 中 断 源 都 相应 地 配备 一 个 中 断 屏 项 触发 需 
(MASK), 则 每 个 中 断 请 求 信 号 在 送 往 判 优 电路 之 前 ,还 要 受 
到 屏蔽 触发 器 的 控制 。 当 MASK==1, 表 示 对 应 中 断 源 的 请 求 
被 屏蔽 ,可 见 中 断 请 求 触发 器 和 中 断 屏 项 触发 器 是 成 对 出 现 
的 ,只 有 当 INTR; 二 1( 中 断 源 有 中 断 请 求 ), MASK; 二 0( 该 级 
中 断 未 被 屏蔽 ) 时 , 才 人 允许 对 应 的 中 断 请 求 送 往 CPU ,相应 的 电 
路 如 图 9-14 所 示 。 

在 中 断 接 口 电 路 中 ,多 个 屏蔽 触发 器 组 成 一 个 屏蔽 寄存 
器 ,其 内 容 称 为 屏蔽 字 或 屏蔽 码 , 由 程序 来 设置 。 屏 项 字 某 一 位 的 状态 将 成 为 本 中 断 源 能 否 
真正 发 出 中 断 请 求 信 号 的 必要 条 件 之 一 。 这 样 , 就 可 实现 CPU 对 中 断 处 理 的 控制 ,使 中 断 
能 在 系统 中 合理 协调 地 进行 。 中 断 屏 项 寄存 器 的 作用 如 图 9-15 所 示 。 具 体 地 说 ,用 程序 设 
置 的 方法 将 屏蔽 寄存 器 中 的 某 一 位 置 “1”, 则 对 应 的 中 断 请 求 被 封锁 ,无 法 去 参加 排队 判 优 ; 
否 屏 蔽 寄存 器 中 的 某 一 位 置 “0”, 才 允许 对 应 的 中 断 请 求 送 往 CPU 。 


图 9-14 ”中断 请 求 触发 器 和 
中 断 屏蔽 触发 器 


中 上 断 屏 天 
寄存 器 


IRs IR; IR, IR 
图 9-15 中断 屏蔽 寄存 器 的 作用 
例如 ,一 个 中 断 系统 有 16 个 中 断 源 ,每 一 个 中 断 源 按 其 优先 级 别 赋予 一 个 屏蔽 字 。 屏 


向 字 与 中 断 源 的 优先 级 别 是 一 一 对 应 的 ，0” 表 示 开 放 ，1” 表 示 屏 蔽 。 表 9-1 中 列 出 了 各 中 
断 源 对 应 的 屏蔽 字 。 
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表 9-1 各 中 断 源 的 屏蔽 字 


中 断 源 的 优先 级 屏蔽 字 (16 位 ) 
1 111…111 
2 011…111 
3 001…111 
15 000…011 
16 000…001 


表 9-1 中 第 1 级 中 断 源 的 屏蔽 字 是 16 个 “1”, 它 的 优先 级 别 最 高 ,禁止 本 级 和 更 低级 的 
中 断 请 求 …… 第 16 级 中 断 源 的 屏蔽 字 只 有 第 16 位 (最 低位 ) 为 “1”, 其 余 各 位 均 为 “0”, 它 的 
优先 级 别 最 低 , 仅 禁止 本 级 的 中 断 请 求 , 而 对 其 他 高 级 的 中 断 请 求全 部 开放 。 

也 有 些 中 断 请 求 是 不 可 屏 项 的 , 即 不 受 中 断 屏 蔽 寄存 器 的 控制 。 这 种 中 断 源 的 中 断 请 
求 一 旦 提出 ,CPU 必须 立即 啊 应 ,它们 具有 最 高 的 优先 级 别 。 例 如 ,电源 掉 电 、 主 存 校 验 


4. 中 断 升级 


中 断 屏蔽 字 的 另 一 个 作用 是 可 以 改变 中 断 优先 级 ,将 原 级 别 较 低 的 中 断 源 变 成 较 高 的 
级 别 , 称 为 中 断 升级 。 这 实际 上 是 一 种 动态 改变 优先 级 的 方法 。 

这 里 所 说 的 改变 优先 次 序 ,是 指 改变 中 断 的 处 理 次 序 。 中 断 处理 次 序 和 中 断 啊 应 次 序 
是 两 个 不 同 的 概念 ,中 断 啊 应 次 序 是 由 硬件 排队 电路 决定 的 ,无 法 改变 。 但 是 ,中 断 处 理 次 
序 是 可 以 由 屏蔽 码 来 改变 的 , 故 把 屏蔽 码 看 成 软 排 队 器 。 中 断 处 理 次 序 可 以 不 同 于 中 断 啊 
应 次 序 。 

例如 , 某 计 算 机 的 中 断 系 统 有 4 个 中 断 源 , 每 个 中 断 源 对 应 一 个 屏蔽 码 。 表 9-2 为 程序 
优先 级 与 屏蔽 码 的 关系 ,中 断 啊 应 的 优先 次 序 为 1 一 2 一 3 一 4。 根 据 表 9-2 给 出 的 屏蔽 码 ,中 
新 的 处 理 次 序 和 中 断 的 啊 应 次 序 是 一 致 的 。 


表 9-2 程序 优先 级 与 屏蔽 码 


屏 蔽 码 
程序 级 别 
E 
第 1 级 1 1 1 1 
第 2 级 0 1 1 1 
第 3 级 0 0 1 1 
第 4 级 0 0 0 1 


根据 这 一 次 序 , 可 以 看 到 CPU 运动 的 轨迹 ,如 图 9-16 所 示 。 当 多 个 中 断 请 求 同 时 出 现 
时 ,处 理 次 序 与 响应 次 序 一 致 ; 当 中断 请 求 先后 出 现时 ,人 允许 优先 级 别 高 的 中 断 请 求 打 断 优 
先 级 别 低 的 中 断 服 务 程序 ,实现 中 断 艇 套 。 

在 不 改变 中 断 响应 次 序 的 条 件 下 ,通过 改写 屏蔽 码 可 以 改变 中 断 处 理 次 序 。 例 如 ,要 使 
中 断 处 理 次 序 改 为 14 一 3 一 2, 则 只 须 使 中 断 屏蔽 码 改 为 如 表 9-3 所 示 即 可 。 
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图 9-16 ”CPU 的 运动 轨迹 


表 9-3 改变 处 理 次 序 的 屏蔽 码 


1 1 1 1 
0 1 0 0 
0 | 1 0 
0 1 1 1 


在 同样 中 断 请 求 的 情况 下 ,CPU 的 运动 轨迹 发 生 了 变化 ,如 图 9-17 所 示 。CPU 正在 执 
行 现行 程序 时 ,中 断 源 Q、@、@ 同 时 请 求 中 断 服务 ,显然 它们 都 没有 被 屏蔽 。 按 照 中 断 优先 
级 别 的 高 低 ,CPU 首先 啊 应 并 处 理 第 中 级 中 断 请 求 ; 当 第 中 级 中 断 处 理 完 后 , 啊 应 第 包 级 中 
断 请 求 。CPU 在 处 理 第 包 级 中 断 时 ,其 屏蔽 码 对 第 由 级 中 断 是 开放 的 ,所 以 当 四 级 的 中 断 
服务 程序 执行 到 开 中 断 指令 后 ,立即 被 四 级 中 断 请 求 打 断 ,CPU 转 去 执行 由 级 的 中 断 服务 
程序 , 待 @ 级 的 中 断 服务 程序 执行 完毕 后 再 返回 接着 执行 @@ 级 中 断 服务 程序 。 当 第 @ 级 中 
断 请 求 到 来 并 在 执行 其 中 断 服务 程序 的 过 程 中 ,又 来 了 也 级 中 断 请 求 ,3 级 中 断 服务 程序 将 
被 四 级 中 断 请 求 打 断 , 转 去 执行 级 中 断 服务 程序 。 在 此 过 程 中 ,虽然 出 现 了 @ 级 中 断 请 
求 ,但 因 @ 级 的 处 理 级 别 最 低 , 故 不 理 皮 它 的 请 求 ,直至 级 的 中 断 服务 程序 执行 完毕 , 青 啊 


应 第 乌 级 中 断 请 求 。 
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图 9-17 处 理 次 序 改变 后 的 CPU 运动 轨迹 


由 此 可 见 , 屏 项 技术 向 使 用 者 提供 了 一 种 手段 , 即 可 以 用 程序 控制 中 断 系 统 ,动态 地 调 
度 多 重 中 断 优 先 处 理 的 次 序 , 从 而 提高 了 中 断 系 统 的 灵活 性 。 
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9.3.5 中 新 全 过 程 


这 里 所 说 的 中 断 全 过 程 , 指 的 是 从 中 断 源 发 出 中 断 请 求 开始 ,CPU 响应 这 个 请 求 ,现行 
程序 被 中 断 , 转 至 中 断 服务 程序 ,直到 中 断 服务 程序 执行 完 。 
毕 ,CPU 再 返回 原来 的 程序 继续 执行 的 整个 过 程 。 

大 体 上 可 以 把 中 断 全 过 程 分 为 5 个 阶段 : 中 断 请 求 、 

中 断 判 优 . 中 断 响应 ,中断 处 理 和 中 断 返 回 。 判断 中 断 源 

其 中 中 断 处 理 就 是 执行 中 断 服 务 程序 ,这 是 中 断 系统 的 
核心 。 不 同 计算 机 系统 的 中 断 处 理 过程 各 具 特 色 , 但 对 多 数 
计算 机 而 言 ,其 中 断 服务 程序 的 流程 如 图 9-18 所 示 。 图 中 灰 
框 代表 一 条 指令 , 白 底 框 代表 一 段 程序 ,往往 不 止 一 条 指令 。 

中 断 处 理 过 程 基本 上 由 3 个 部 分 组 成 (以 多 重 中 断 为 
例 ) ,第 一 部 分 为 准备 部 分 ,其 基本 功能 是 保护 现场 ,对 于 非 
向 量 中 断 方式 则 需要 确定 中 断 源 ,最 后 开放 中 断 ,允许 更 高 
级 的 中 断 请 求 打 断 低级 的 中 断 服 务 程序 ;第 二 部 分 为 处 理 
部 分 , 即 真 正 执行 具体 的 为 某 个 中 断 源 服务 的 中 断 服务 程 1 一) 
序 ;第 三 部 分 为 结尾 部 分 ,首先 要 关中 断 , 以 防止 在 恢复 现 
场 过 程 中 被 新 的 中 断 请 求 打 断 ,接着 恢复 现场 ,然后 开放 中 |。 出 晰 服务 程 库 的 六 和 
盯 ,以 便 返回 原来 的 程序 后 可 啊 应 其 他 的 中 断 请 求 。 中 断 
服务 程序 的 最 后 一 条 指令 一 定 是 中 断 返 回 指令 。 

注意 ; 保护 现场 之 前 的 关中 断 操作 由 中 断 隐 指令 完成 

多 重 中 断 与 单 重 中 断 在 中 断 服 务 程 序 的 执行 中 有 所 不 同 , 表 9-4 列 出 了 两 者 的 区 别 。 


表 9-4 多 重 中 断 与 单 重 中 断 的 区 别 


准备 部 分 


执行 中 断 


服务 程序 Jam 


中 断 处 理 过 程 


结尾 部 分 


操作 类 型 多 重 中 断 方 式 单 重 中 断 方式 
关中 断 关中 断 
中 断 隐 指 令 保存 断 点 及 旧 PSW 保存 断 点 及 旧 PSW 
取 中 断 服 务 程序 人 口 地 址 及 新 PSW 取 中 断 服 务 程 序 人 口 地 址 及 新 PSW 
保护 现场 
送 新 屏蔽 字 保护 现场 
开 中 断 


服务 处 理 服务 处 理 
中 断 服务 程序 (允许 啊 应 更 高 级 别 请 求 ) (不 允许 啊 应 更 高 级 别 请 求 ) 


关中 断 

恢复 现场 及 原 屏 菩 字 恢复 现场 
开 中 断 开 中 断 
中 断 返 回 中 断 返 回 


9.3.6 程序 中 新 接口 结构 
具有 中 断 能 力 的 外 设 接 口 是 由 程序 查询 式 接口 再 加 上 中 断 控制 机 构 组 成 的 。 侧 化 的 中 
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断 式 接口 如 图 9-19 所 示 。 从 其 逻辑 功能 来 看 ,这 个 接口 不 仅 可 以 保证 中 断 式 传送 ,而 且 也 
可 以 提供 程序 查询 式 传送 。 图 中 AB、DB、CB 分 别 表示 地 址 总 线 、 数 据 总 线 和 控制 总 线 。 
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9-19 简化 的 中 断 式 接口 


中 断 控 制 机 构 至 少 应 包括 有 下 列 几 个 部 分 。 

(1) 中 断 请 求 电 路 

当中 断 源 有 请 求 且 中 断 开放 时 ,中 断 请 求 电 路 癌 CPU 发 中 断 请 求 信和 号。 

(2) 中 断 优 先 级 电路 

中 断 优先 级 电路 保证 优先 级 别 最 高 的 中 断 源 首先 获得 CPU 的 服务 。 

(3) 回 量 地 址 形成 部 件 

向 量 地 址 形成 部 件 用 来 产生 向 量 中 断 时 需要 的 向 量 地 址 ,并 且 根 据 这 个 向 量 地 址 转向 
该 中 断 源 所 对 应 的 中 断 服务 程序 。 


9.4 DMA 方式 及 其 接口 


DMA 方式 是 为 了 在 主 存 与 外 设 之 间 实 现 高 速 、 批 量 数据 交换 而 设置 的 。DMA 方式 的 
数据 传送 直接 依 徘 鲁 件 (DMA 控制 部 ) 来 实现 ,不 需要 执行 任何 程序 。 


9.4.1 DMA 方式 的 基本 概念 
1. DMA 方式 的 特点 


无 论 程 序 查询 还 是 程序 中 断 方式 ,主要 的 工作 都 是 由 CPU 执行 程序 完成 的 ,这 需要 占 
用 CPU 时 间 ,因此 不 能 实现 高 速 外 设 与 主机 的 信息 交换 。 

直接 存储 需 访 问 (Direct Memory Access,DMA) 方 式 是 在 外 设 和 主 存 之 间 开 尽 一 条 
“直接 数据 通道 ,在 不 需要 CPU 干预 也 不 需要 软件 介入 的 情况 下 在 两 者 之 间 进 行 的 高 速 
数据 传送 方式 。 在 DMA 传送 方式 中 ,对 数据 传送 过 程 进行 控制 的 便 件 称 为 DMA 控制 硕 。 
当 外 设 需 要 进行 数据 传送 时 ,通过 DMA 控制 器 问 CPU 提出 DMA 传送 请 求 ,CPU 啊 应 之 
后 将 让 出 系统 总 线 , 由 DMA 控制 器 接管 总 线 进行 数据 传送 。 
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DMA 方式 具有 下 列 特 点 : 

QO 它 使 主 存 与 CPU 的 固定 联系 脱 钧 , 主 存 既 可 被 CPU 访问 ,又 可 被 外 设 访问 。 

@ 在 数据 块 传送 时 , 主 存 地 址 的 确定 、 传 送 数据 的 计数 等 都 由 硬件 电路 直接 实现 。 
@ 主 存 中 要 开辟 专用 缓冲 区 ,及 时 供给 和 接收 外 设 的 数据 。 

@ DMA 传送 速度 快 ,CPU 和 外 设 并 行 工作 ,提高 了 系统 的 效率 。 

@ DMA 在 传送 开始 前 要 通过 程序 进行 预 处 理 ,结束 后 要 通过 中 断 方式 进行 后 处 理 。 


2. DMA 和 中 断 的 区 别 


DMA 与 中 断 的 主要 区 别 如 下 : 

Q9 中 断 方式 是 程序 切换 ,需要 保护 和 恢复 现场 ;而 DMA 方式 除了 开始 和 结尾 时 ,不 占 
用 CPU 的 任何 资源 。 

Q 对 中 断 请 求 的 啊 应 时 间 只 能 发 生 在 每 条 指令 执行 完毕 时 ;而 对 DMA 请 求 的 啊 应 时 
间 可 以 发 生 在 每 个 机 器 周期 结束 时 ,如 图 9-20 所 示 。 


| 取 指 令 tt 执行 


DMA 断 点 中 断 断 点 
图 9-20 ”两 种 请 求 的 响应 时 刻 比 较 


@ 中 断 传送 过 程 需要 CPU 的 干预 ;而 DMA 传送 过 程 不 需要 CPU 的 干预 , 故 数据 传 
输 速 率 非 常 高 ,适合 于 高 速 外 设 的 成 组 数据 传送 。 

由 DMA 请 求 的 优先 级 高 于 中 断 请 求 。 

@ 中 断 方式 具有 对 异常 事件 的 处 理 能 力 ,而 DMA 方式 仅 局 限于 完成 传送 数据 块 的 
LI/O 操作 。 


3. DMA 方式 的 应 用 


DMA 方式 一 般 应 用 于 主 存 与 高 速 外 设 间 的 简单 数据 传送 。 如 磁盘 、 磁 市 、 光 盘 等 辅助 
存储 硕 以 及 其 他 带 有 局 部 存储 硕 的 外 设 .通信 设备 等 都 是 高 速 外 设 。 

对 磁盘 的 读 写 是 以 数据 块 为 单位 进行 的 ,一 旦 找到 数据 块 起 始 位 置 ,就 将 连续 地 读 写 。 
从 磁盘 中 读 出 数据 或 往 磁盘 中 写 入 数据 时 ,一 般 采 用 DMA 方式 传送 , 即 直 接 将 数据 由 主 存 
经 数据 总 线 输 出 到 磁盘 接口 ,然后 写 人 盘 片 ;或 将 数据 由 盘 片 谈 出 到 磁盘 接口 ,然后 经 数据 
总 线 写 人 主 存 。 

在 大 批量 数据 采集 系统 中 ,也 可 以 采用 DMA 方式 。 

许多 计算 机 系统 中 选用 动态 存储 器 (DRAM) ,并 用 异步 方式 安排 刷新 周期 。DRAM 的 
刷新 操作 可 视 为 存储 部 内 部 的 数据 批量 传送 ,因此 ,也 可 采用 DMA 方式 实现 ,将 每 次 刷新 
请 求 当 成 DMA 请 求 。CPU 在 刷新 周期 中 让 出 系统 总 线 , 按 行 地 址 (刷新 地 址 ) 访 问 主 存 ， 
实现 各 芯片 中 的 一 行 刷 新 。 利 用 系统 的 DMA 机 制 实现 动态 刷新 ,简化 了 专门 的 动态 刷新 
逻辑 ,提高 了 主 存 的 利用 率 。 

DMA 传送 是 直接 依 蚕 便 件 实现 的 ,可 用 于 快速 的 数据 特 传 。 也 正 是 由 于 这 一 点 ， 


是 
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DMA 方式 本 身 不 能 处 理 较 复杂 的 事件 。 因 此 ,在 菜 些 场合 种 综合 应 用 DMA 方式 与 程序 中 
断 方式 ,二 者 互 为 补充 。 


9.4.2 DMA 接口 


DMA 接口 相对 于 查询 式 接口 和 中 断 式 接口 来 说 比较 复杂 ,习惯 将 DMA 方式 的 接口 电 
路 称 为 DMA 控制 硕 。 


1. DMA 控制 器 的 功能 


在 DMA 传送 过 程 中 ,DMA 控制 器 将 接管 CPU 的 地 址 总 线 、 数 据 总 线 和 控制 总 线 ， 
CPU 的 主 存 控制 信号 被 禁止 使 用 。 而 当 DMA 传送 结束 后 ,将 恢复 CPU 的 一 切 权 力 并 开 
始 执行 其 操作 。 由 此 可 见 ,DMA 控制 器 必须 具有 控制 系统 总 线 的 能 力 ,也 就 是 说 能 够 像 
CPU 一 样 输出 地 址 信号 ,接收 或 发 出 控制 信号 ,输入 或 输出 数据 信号。 

DMA 控制 器 在 外 设 与 主 存 之 间 直 接 传送 数据 期 间 , 完 全 代替 CPU 进行 工作 , 它 的 主 
要 功能 有 : 

Q 接受 外 设 发 出 的 DMA 请 求 ,并 向 CPU 发 出 总 线 请 求 。 

@ 当 CPU 响应 此 总 线 请 求 ,发 出 总 线 响 应 信号 后 ,接管 对 总 线 的 控制 ,进入 DMA 操 
作 周 期 。 

G) 确定 传送 数据 的 主 存单 元 地 址 及 传送 长 度 ,并 能 自动 修改 主 存 地 址 计数 值 和 传送 长 
度 计 数值 。 

@ 规定 数据 在 主 存 与 外 设 之 间 的 传送 方向 ,发 出 读 写 或 其 他 控制 信号 ,并 执行 数据 传 
送 的 操作 。 

@@ 向 CPU 报告 DMA 操作 的 结束 。 


2. DMA 控制 器 的 基本 组 成 
图 9-21 给 出 了 一 个 简单 的 DMA 控制 器 框图 , 它 由 以 下 几 部 分 组 成 。 


| 
主 存 地 址 计数 各 


一 


9-21 简单 的 DMA 控制 器 


(1) 主 存 地 址 计数 需 
主 存 地 址 计数 需 用 来 存放 竺 交换 数据 的 主 存 地 址 。 该 计数 需 的 初始 值 为 主 存 缓冲 区 的 
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首 地 址 , 当 DMA 传送 时 ,每 传送 一 个 数据 ,将 地 址 计数 器 加 1, 从 而 以 增 量 方式 给 出 主 存 中 
要 交换 的 一 批 数据 的 地 址 ,直至 这 批 数据 传送 完毕 为 止 。 

(2) 传送 长 度 计 数 器 

传送 长 度 计 数 器 用 来 记录 传送 数据 块 的 长 度 。 其 初始 值 为 传送 数据 的 总 字数 或 总 字 节 
数 , 每 传送 一 个 字 或 一 个 字 节 ,计数 器 自动 减 1, 当 其 内 容 为 0 时 表示 数据 已 全 部 传送 完毕 。 
也 有 些 DMA 控制 器 中 ， ee 个 字 或 一 个 字 

节 , 计 数 器 加 1, 当 计 数 器 溢出 时 ,表示 数据 传送 完毕 。 

(3) 数据 缓冲 寄存 器 

数据 缓冲 寄存 器 用 来 暂 存 每 次 传送 的 数据 。 输 入 时 ,数据 由 外 设 ( 如 磁盘 ) 先 送 往 数据 
缓冲 寄存 器 ,再 通过 数据 总 线 送 到 主 存 。 反 之 ,输出 时 ,数据 由 主 存 通过 数据 总 线 送 到 数据 
缓冲 寄存 器 ,然后 再 送 到 外 设 。 

(4) DMA 请 求 触发 器 

DMA 请 求 触 发 大 的 作用 是 每 当 外 设 准备 好 数据 后 给 出 一 个 控制 信号 ,使 DMA 请 求 触 
发 器 置 位 。 

(5) 控制 /状态 逻辑 

它 由 控制 和 时 序 电 路 以 及 状态 标志 等 组 成 ,用 于 指定 传送 方向 ,修改 传送 参数 ,并 对 
DMA 请 求 信 号 和 CPU 啊 应 信号 进行 协调 和 同步 。 

(6) 中 断 机 构 

当 一 个 数据 块 传送 完毕 后 触发 中 断 机 构 ,向 CPU 提出 中 断 请 求 ,CPU 将 进行 DMA 传 
送 的 结尾 处 理 。 

有 些 商品 化 的 DMA 控制 器 芯片 中 看 似 并 没有 设置 中 断 机 构 ,但 并 不 代表 DMA 的 结 
尾 处 理 不 需要 中 断 的 参与 ,因为 系统 一 定 还 同时 配 有 中 断 控制 器 芒 片 ,两 个 芯片 共同 完成 了 
DMA 的 功能 。 


3. DMA 控制 器 的 引出 线 


DMA 控制 器 必须 有 下 列 引 出 线 。 

(1) 地 址 线 

在 DMA 方式 下 ,地 址 线 呈 输出 状态 ,可 对 主 存 进行 地 址 选择 ;在 CPU 方式 下 ,地 址 线 
呈 输 入 状态 ,可 对 DMA 控制 器 中 的 有 关 寄 存 硕 进行 寻 址 。 

(2) 数据 线 

在 DMA 方式 下 ,用 它 进行 数据 传送 ;在 CPU 方式 下 ,可 对 DMA 控制 器 的 有 关 寄 存 器 
进行 编程 。 

(3) 控制 数据 传送 方式 的 信号 线 

存储 器 读 信 号 MEMR ,存储 器 写 信 号 MEMW 外 设 读 信和 号 IOR 和 外 设 写 信和 号 IOW 。 

当 数 据 从 外 设 写 入 主 存 时 , MEMW 和 1IOR 同 时 有 效 ; 而 当 数 据 从 主 存 读 出 送 外 设 时 ， 
MEMR 和 IOW 将 同时 有 效 。 

(4) DMA 控制 需 与 外 设 之 间 的 联络 信号 线 

DMA 请 求 信 号 DREQ( 输 入 ) 是 外 设 癌 DMA 控制 需 提 出 DMA 操作 的 申请 信号 。 

DMA 啊 应 信号 DACK( 输 出 ) 是 DMA 控制 希 给 提出 DMA 请 求 的 外 设 的 应 答 信 号 。 
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(5) DMA 控制 器 与 CPU 之 间 的 联络 信和 号 线 
总 线 请 求 信 号 HRQ( 输 出 ) 是 DMA 控制 器 向 CPU 请 求 使 用 总 线 的 信号 
总 线 啊 应 信号 HLDA( 输 入 ) 是 CPU 向 DMA 控制 需 表 示 啊 应 总 线 请 求 的 信和 号。 


4. DMA 控制 器 的 连接 和 传送 


图 9-22 给 出 了 DMA 控制 器 与 CPU 及 主 存 、 外 设 之 间 的 连接 框图 。 在 进行 DMA 操作 
之 前 应 先 对 DMA 控制 器 编程 。 例 如 ,确定 传送 数据 的 主 存 起 始 地 址 、 要 传送 的 字 节 数 以 及 
传送 方式 ,是 由 外 设 将 数据 写 入 主 存 还 是 从 主 存 将 数据 读 出 送 外 设 。 下 面 以 外 设 将 一 个 数 
据 块 写 入 主 存 的 操作 为 例 , 简 述 DMA 控制 大 的 操作 过 程 。 


| ls 
MEMW 
四 ee 
数据 总 线 
J 数据 线 
DREQ 
DACK | 外 设 
HLDA IOW 
IOR 


9-22 DMA 控制 器 与 CPU 及 主 存 、 外 设 之 间 的 连接 


a` 由 外 设 向 DMA 控制 器 发 出 DMA 请 求 信号 DREQ.。 

@ DMA 控制 器 向 CPU 发 出 总 线 请 求 信 号 HRQ。 

G@ CPU 向 DMA 控制 器 发 出 总 线 啊 应 信号 HLDA ,此 时 DMA 控制 器 获取 了 总 线 的 控 
制 权 。 

@ DMA 控制 器 向 外 设 发 出 DMA 响应 信号 DACK ,表示 DMA 控制 器 已 控制 了 总 线 ， 
允许 外 设 与 主 存 交换 数据 。 

@ DMA 控制 器 按 主 存 地 址 计数 器 的 内 容 发 出 地 址 信号 作为 主 存 地 址 的 选择 ,同时 主 
存 地 址 计数 器 的 内 容 加 1。 

@ DMA 控制 器 发 出 IOR 信 号 到 外 设 , 将 外 设 数据 读 入 数据 缓冲 寄存 器 ,同时 发 出 
MEMW 信 号 ,将 数据 缓冲 寄存 器 中 的 数据 写 人 选中 的 主 存单 元 。 

@) 传送 长 度 计数 器 减 1 。 

重复 @ 一 四 步骤 ,直到 字 节 计数 需 减 到 0 为 止 ,数据 块 的 DMA 方式 传送 工作 宣告 完 
成 。 这 时 ,DMA 控制 硕 的 HRQ 降 为 低 电 平 ,总 线 控制 权 交 还 CPU 。 


9.4.3 DMA 传送 方法 与 传送 过 程 
1. DMA 传送 方法 


DMA 控制 颖 与 CPU 通常 采用 以 下 3 种 方法 使 用 主 存 。 
(1) CPU 停止 访问 主 存 法 
这 是 最 简单 的 DMA 方法 。 这 种 方法 是 用 DMA 请 求 信 号 迫使 CPU 让 出 总 线 控制 权 。 
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CPU 在 现行 机 器 周 期 执行 完成 之 后 ,使 其 数据 、 地 址 总 线 处 于 三 态 , 并 输出 总 线 批准 信号 。 
每 次 DMA 请 求 获得 批准 ,DMA 控制 器 获得 总 线 控制 权 以 后 ,连续 占用 若干 个 存 取 周 期 (总 
线 周 期 ) 进 行 成 组 连续 的 数据 传送 ,直至 批量 传送 结束 ,DMA 控制 器 才 把 总 线 控制 权 交 回 
CPU。 在 DMA 操作 期 间 ,CPU 处 于 保持 状态 ,停止 访问 主 存 , 仅 能 进行 一 些 与 总 线 无 关 的 
内 部 操作 。 图 9-23(a) 是 这 种 传送 方法 的 时 间 图 ,该 方法 只 适用 于 高 速 外 设 的 成 组 传送 。 


CPU 控制 并 


使 用 主 存 | DMA 不 工作 | | DMA 不 工作 | 
DMA 控 制 并 三- 一 一 一 一 一 一 一 一 一 一 一 一 
使 用 主 存 | | DMA 工作 | 
主 存 工作 时 间 - 
(a) 

CPU 探 制 并 于 一 一 
使 用 主 存 | 1 1 1 |1 | 1 1 1 | 
PMA 接 制 并 于 一 站 站 一 
使 用 主人 | | 1 1 1 1 1 1 


存 工作 时 间 [一 -一 一 一 一 -一 一 一 
(b) 


CPU 控制 并 
使 用 主 存 
DMA 控制 并 
使 用 主 存 
主 存 工作 时 间 


9-23 ”DMA 传送 方法 


当 外 设 的 数据 传输 率 接近 于 主 存 工作 速度 时 ,或 者 CPU 除了 等 待 DMA 传送 结束 并 无 


其 他 事 可 于 (如 单 用 户 状 态 下 的 个 人 计算 机 ) 时 , 常 采 用 这 种 方法 。 它 可 以 减少 系统 总 线 控 
制 权 的 交换 次 数 , 有 利于 提高 输入 输出 的 速度 。 
(2) 存储 需 分 时 法 


把 原来 的 一 个 存 取 周期 分 成 两 个 时 间 片 ,一 片 分 给 CPU ,一 片 分 给 DMA ,使 CPU 和 
DMA 交替 地 访问 主 存 。 这 种 方法 无 须 申 请 和 归还 总 线 , 使 总 线 控制 权 的 转移 几乎 不 需要 
什么 时 间 ,所 以 对 DMA 传送 来 讲 效 率 是 很 高 的 ,而 且 CPU 既 不 停止 现行 程序 的 运行 ,也 不 
进入 保持 状态 ,在 CPU 不 知 不 觉 中 便 进 行 了 DMA 传送 ;但 这 种 方法 需要 主 存在 原来 的 存 
取 周 期 内 为 两 个 部 件 服务 ,如 果 要 维持 CPU 的 访 存 速度 不 变 , 就 要 求 主 存 的 工作 速度 提高 
一 倍 。 另 外 ,由 于 大 多 数 外 设 的 速度 都 不 能 与 CPU 相 匹 配 ,所 以 供 DMA 使 用 的 时 间 片 可 
能 成 为 空 操作 ,将 会 造成 一 些 不 必要 的 浪费 。 图 9-23(b) 是 这 种 方法 的 时 间 图 。 

(3) 周期 挪用 法 

周期 挪用 法 是 前 两 种 方法 的 折 中 。 当 外 设 没有 DMA 请 求 时 ,CPU 按 程序 要 求 访 问 主 
存 ;一 旦 外 设 有 DMA 请 求 并 获得 CPU 批准 后 ,CPU 让 出 一 个 周期 的 总 线 控制 权 , 由 DMA 
控制 磊 控 制 系统 总 线 ,挪用 一 个 存 取 周 期 进行 一 次 数据 传送 ,传送 一 个 字 节 或 一 个 字 ;然后 ， 
DMA 控制 器 将 总 线 控制 权 交 回 CPU,CPU 继续 进行 自己 的 操作 ,等待 下 一 个 DMA 请 求 
的 到 来 。 重复 上 述 过 程 ,直至 数据 块 传送 完毕 。 如 果 在 同一 时 刻 ,发 生 CPU 与 DMA 的 访 
存 冲 突 ,那么 优先 保证 DMA 工作 ,而 CPU 等 待 一 个 存 取 周期 ,如 图 9-23(c) 所 示 。 若 DMA 
传送 期 间 CPU 无 须 访 存 , 则 周期 挪用 对 CPU 执行 程序 无 任何 影响 。 


9 
章 
ES 


计算 机 组 成 原理 (第 4 版 ) 


当主 存 工作 速度 高 出 外 设 较 多 时 ,采用 周期 挪用 法 可 以 提高 主 存 的 利用 率 ,对 CPU 的 
影响 较 小 ,因此 ,高 速 主机 系统 常 采 用 这 种 方法 。 根据 主 存 的 存 取 周 期 与 磁盘 的 数据 传输 
率 , 可 以 计算 出 主 存 操作 时 间 的 分 配 情况 : 有 多 少时 间 需 用 于 DMA 传送 (被 挪用 ) ,有 多 少 
时 间 可 用 于 CPU 访 存 。 这 在 一 定 程度 上 反映 了 系统 的 处 理 效率 。 


2. DMA 传送 过 程 


DMA 的 传送 过 程 可 分 为 3 个 阶段 : DMA 传送 前 的 预 处 理 、 数 据 传送 和 传送 后 的 结束 
处 理 。 

(1) DMA 预 处 理 

在 DMA 传送 之 前 必须 要 做 准备 工作 , 即 初始 化 。 这 是 DMA 请 求 
由 CPU 来 完成 的 。CPU 首先 执行 几 条 1/O 指令 ,用 于 测试 
外 设 的 状态 .向 DMA 控制 器 的 有 关 寄 存 器 置 初 值 \ 设 置 传送 


方向 .启动 该 外 部 设备 等 。 
在 这 些 工 作 完 成 之 后 ,CPU 继续 执行 原来 的 程序 ,在 外 

设 准备 好 发 送 的 数据 (输入 ) 或 接收 的 数据 已 处 理 完毕 ( 输 Ns 

出 ) 时 ,外 设 向 DMA 控制 器 发 DMA 请 求 ,再 由 DMA 控制 (或 主 存 ) 

需 癌 CPU 发 总 线 请 求 。 本 _] 
(2) 数据 传送 


DMA 的 数据 传送 可 以 以 单字 节 ( 或 字 ) 为 基本 单位 ,也 
可 以 以 数据 块 为 基本 单位 。 对 于 以 数据 块 为 单位 的 传送 ， 
DMA 控制 器 占用 总 线 后 的 数据 输入 和 输出 操作 都 是 通过 循 
环 来 实现 的 ,其 传送 过 程 如 图 9-24 所 示 。 
注意 ; 图 9-24 所 示 的 流程 图 不 是 由 CPU 执行 程序 实现 程序 中 断 
的 ,而 是 由 DMA 控制 器 实现 的 。 9-24 DMA 的 数据 传送 过 程 
(3) DMA 后 处 理 
当 传 送 长 度 计 数 器 计 到 0 时 ,DMA 操作 结束 ,DMA 控制 器 疝 CPU 发 中 断 请 求 ,CPU 
停止 原来 程序 的 执行 , 转 去 执行 中 断 服务 程序 做 DMA 结束 处 理工 作 。 


9.5 通 追 控制 方式 


在 大 型 计算 机 系统 中 ,所 连接 的 1/O 设备 数量 多 ,输入 输出 频 紧 ,要 求 整 体 的 速度 快 ， 
单纯 依 徘 主 CPU 采取 程序 中 断 和 DMA 等 控制 方式 已 不 能 满足 要 求 , 于 是 通道 控制 方式 被 
引入 计算 机 系统 。 


9.5.1 通道 的 基本 概 会 
1. 通道 控制 方式 与 DMA 方式 的 区 别 


通道 控制 方式 是 DMA 方式 的 进一步 发 展 ,实质 上 ,通道 也 是 实现 外 设 和 主 存 之 间 直 
接 交 换 数 据 的 控制 项 。 与 DMA 控制 带 相 比 ,两 者 的 主要 区 别 在 于 : 
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J DMA 控制 部 是 通过 专门 设计 的 便 件 控制 逻辑 来 实现 对 数据 传送 的 控制 ;而 通道 则 
是 一 个 具有 特殊 功能 的 处 理 融 , 它 具 有 目 己 的 指令 和 程序 ,通过 执行 通道 程序 来 实现 对 数据 
传送 的 控制 , 放 通 站 具有 更 强 的 独立 处 理 数 据 输 入 输出 的 功能 。 

Go DMA 控制 融通 第 只 能 控制 一 台 或 少数 几 台 同类 设备 ;而 一 个 通道 则 可 以 同时 控制 
许多 人 台 同类 或 不 同类 的 设备 。 


2. 通道 的 功能 


在 第 1 半 已 经 引出 了 典型 的 具有 通道 的 计算 机 结构 。 从 图 1-4 中 可 以 看 出 ,主机 可 以 
接 奋 干 个 通道 ,一 个 通关 可 以 接 右 干 个 设备 控制 硕 ,一 个 设备 控制 部 又 可 以 接 一 台 或 多 人 台 外 
部 设备 。 因 此 ,从 逻辑 结构 上 讲 ,通道 控制 方式 具有 4 级 连接 : 主机 一 通道 一 设备 控制 希 一 
外 部 设备 。 
通道 是 一 种 高 级 的 IVO 控制 部 件 , 它 在 一 定 的 硬件 基础 上 利用 软件 手段 实现 对 1/O 的 
控制 和 传送 ,更 多 地 免 去 了 CPU 的 介入 ,从 而 使 主机 和 外 设 的 并 行 工 作 程度 更 高 。 当 然 ， 
通道 并 不 能 完全 脱离 CPU , 它 还 要 受到 CPU 的 管理 ,如 启动 .停止 等 ,而 且 通 道 还 应 该 向 
CPU 报告 自己 的 状态 ,以 便 CPU 决定 下 一 步 的 处 理 。 
通道 应 具有 以 下 几 个 方面 的 功能 : 
中 接受 CPU 的 IO 指令 , 按 指令 要 求 与 指定 的 外 设 进行 联系 。 
G@ 从 主 存 取 出 属于 该 通道 程序 的 通道 指令 ,经 译 码 后 问 设 备 控制 器 和 设备 发 送 各 种 
令 。 
(3 实施 主 存 和 外 设 间 的 数据 传送 ,如 为 主 存 或 外 设 装配 和 拆 番 信息 ,提供 数据 中 间 绥 
存 的 空间 以 及 指示 数据 存放 的 主 存 地 址 和 传送 的 数据 量 。 
网 从 外 设 获 得 设备 的 状态 信息 ,形成 并 保存 通道 本 号 的 状态 信息 ,根据 要 求 将 这 些 状 
态 信息 送 到 主 存 的 指定 单元 , 供 CPU 使 用 。 
@ 将 外 设 的 中 断 请 求 和 通道 本 身 的 中 断 请 求 按 次 序 及 时 报告 CPU 。 


9.5.2 通道 的 类 型 与 结构 


1. 通道 类 型 


Ey 


按照 通道 独立 于 主机 的 程度 ,可 分 为 结合 型 通道 和 独立 型 通道 两 种 类 型 。 结 合 型 通道 
在 硬件 结构 上 与 CPU 结合 在 一 起 ,借助 于 CPU 的 某 些 部 件 作 为 通道 部 件 来 实现 外 设 与 主 
机 的 信息 交换 。 这 种 通道 结构 简单 ,成 本 较 低 ,但 功能 较 弱 。 独 立 型 通道 完全 独立 于 主机 对 
外 设 进行 管理 和 控制 。 这 种 通道 功能 强 , 但 设备 成 本 高 。 

按照 输入 输出 信息 的 传送 方式 ,通道 可 分 为 字 节 多 路 通道 .选择 通道 和 数组 多 路 通道 3 
种 类 型 。 

(1) 字 节 多 路 通道 

字 节 多 路 通道 是 一 种 简单 的 共享 通道 ,用 于 连接 与 管理 多 台 低 速 设备 ,以 字 节 交叉 方式 
传送 信息 ,其 传送 方式 如 图 9-25 所 示 。 字 节 多 路 通道 先 选择 设备 A, 为 其 传送 一 个 字 节 
Ai; 然 后 选择 设备 B, 传 送 字 节 Bi ;再 选择 设备 C, 传 送 字 节 Cl 。 再 交叉 地 传送 A, , B, ,C，， 
… 所 以 字 节 多 路 通道 的 功能 好 比 一 个 多 路 开关 ,交叉 (轮流 ) 地 接 通 各 台 设 备 。 
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图 9-25 字 节 多 路 通道 传送 方式 


一 个 字 节 多 路 通道 ,包括 多 个 按 字 贡 方式 传送 信息 的 子 通道 。 每 个 子 通道 服务 于 一 个 
设备 控制 硕 ,每 个 子 通道 都 可 以 独立 地 执行 通道 程序 。 各 个 子 通道 可 以 并 行 工 作 , 但 是 ,所 
有 子 通道 的 控制 部 分 是 公共 的 ,各 个 子 通 道 可 以 分 时 地 使 用 。 

通道 不 间断 地 、 轮 流 地 局 动 每 个 设备 控制 需 , 当 通道 为 一 个 设备 传送 完 一 个 字 节 后 ,就 
转 去 为 另 一 个 设备 服务 。 当 通道 为 某 一 设备 传送 时 ,其 他 设备 可 以 并 行 地 工作 ,准备 需要 传 
送 的 数据 字 节 或 处 理 收 到 的 数据 字 节 。 这 种 轮流 服务 是 建立 在 主机 的 速度 比 外 设 的 速度 高 
得 多 的 基础 之 上 的 , 它 可 以 提高 系统 的 工作 效率 。 

(2) 选择 通道 

对 于 高 速 设备 , 字 节 多 路 通道 显然 是 不 合适 的 。 选 择 通道 又 称 高 速 通道 ,在 物理 上 
它 也 可 以 连接 多 个 设备 ,但 这 些 设备 不 能 同时 工作 ,在 一 段 时 间 内 通道 只 能 选择 一 台 设 
备 进 行 数据 传送 ,此 时 该 设备 可 以 独占 整个 通道 。 因 此 ,选择 通道 一 次 只 能 执行 一 个 通 
道 程序 ,只 有 当 它 与 主 存 交 换 完 信息 后 ,才能 青 选择 男 一 台 外 部 设备 并 执行 该 设备 的 通 
道 程序 。 如 图 9-26 所 示 ,选择 通道 先 选择 设备 A, 成 组 连续 地 传送 AlA,…, 当 设备 A 传 
送 完毕 后 ,选择 通道 又 选择 通道 B, 成 组 连续 地 传送 BB,… ,再 选择 设备 C, 成 组 连续 地 传 
大 CaiLz…。 


图 9-26 选择 通道 传送 方式 


选择 通道 主要 用 于 连接 高 速 外 设 , 如 磁盘 、 磁 带 等 ,信息 以 成 组 方式 高 速 传送 。 但 是 ， 
在 数据 传送 过 程 中 还 有 一 些 辅助 操作 ,如 磁盘 机 的 寻 道 等 ,此 时 会 使 通道 处 于 等 待 状 态 , 所 
以 虽然 选择 通道 具有 很 高 的 数据 传输 速率 ,但 整个 通道 的 利用 率 并 不 高 。 

(3) 数组 多 路 通道 

数组 多 路 通道 是 把 字 节 多 路 通道 和 选择 通道 的 特点 结合 起 来 的 一 种 通道 结构 。 它 的 基 
本 思想 是 : 当 某 设备 进行 数据 传送 时 ,通道 只 为 该 设备 服务 ; 当 设 备 在 执行 辅助 操作 时 , 通 
道 暂 时 断 开 与 这 个 设备 的 连接 , 挂 起 该 设备 的 通道 程序 ,去 为 其 他 设备 服务 。 

数组 多 路 通道 有 多 个 子 通道 , 既 可 以 执行 多 路 通道 程序 , 即 像 字 节 多 路 通道 那样 ,所 有 
子 通道 分 时 共享 总 通道 ,又 可 以 用 选择 通关 那样 的 方式 成 组 地 传送 数据 ; 既 具 有 多 路 并 行 操 
作 的 能 力 , 又 具有 很 高 的 数据 传输 速率 ,使 通道 的 效率 充分 得 到 发 挥 。 
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选择 通 亿 和 数组 多 路 通过 都 适用 于 连接 高 速 外 设 ,但 前 者 的 数据 宽度 是 不 定 长 的 数据 
块 ,后 者 的 数据 宽度 是 定 长 的 数据 块 。3 种 类 型 通道 的 比较 见 表 9-5。3 种 类 型 的 通道 组 织 
在 一 起 ,可 配置 大 干 台 不 同 种 类 不同 速度 的 W/O 设备 ,使 计算 机 的 W/O 组 织 更 合理 、 功 能 
更 完善 \ 管 理 更 方便 。 


表 9-5 3 种 类 型 通道 的 比较 


通道 类 型 十 二 - 、 


数据 宽度 单字 节 不 定 长 块 定 长 块 

适用 范围 大 量 低速 设备 优先 级 高 的 高 速 设备 大 量 高 速 设备 
工作 方式 Ek 独占 通道 成 组 交叉 
共享 性 分 时 共享 独占 分 时 共享 
选择 设备 次 数 多 次 = 多 次 


通道 在 单位 时 间 内 传送 的 位 数 或 字 节 数 称 为 通道 的 数据 传输 率 或 流量 , 它 标志 了 计算 
机 系统 中 的 系统 厨 吐 量 ,也 表明 了 通 近 对 外 设 的 控制 能 力 和 效率 。 在 单位 时 间 内 人 允许 传送 
的 最 大 字 节 数 或 位 数 称 为 通道 的 最 大 数据 传输 率 或 通道 极限 流量 , 它 是 设计 通道 的 最 大 
依据 。 

字 节 多 路 通道 的 实际 流量 是 该 通道 上 所 有 设备 的 数据 传输 率 之 和 。 而 选择 通道 和 数组 
多 路 通道 在 一 段 时 间 内 只 能 为 一 台 设 备 传送 数据 ,这 时 的 通道 流量 就 等 于 这 人 台 设 备 的 数据 
传输 率 。 因 此 ,这 两 种 通道 的 实际 流量 等 于 连接 在 这 个 通 近 上 的 所 有 设备 中 流量 最 大 的 那 


下 


2. 通道 的 结构 


通道 的 一 般 逻 辑 结构 如 图 9-27 所 示 , 其 中 CSWR CAWR .CCWR 是 3 个 重要 的 寄存 
右 。CCWR 是 通道 命令 字 寄 存 右 , 它 用 来 存放 通道 命令 字 (CCW)。CCW 是 控制 1/O 操作 
的 关键 参数 ,一 条 条 的 通道 命令 字 ( 通 道 指令 ) 构 成 通道 程序 , 放 在 主 存 中 。CAWR 是 通道 
地 址 字 寄 存 器 , 它 指出 了 通道 程序 在 主 存 中 的 起 始 地 址 ,工作 时 通道 就 依照 这 个 地 址 到 主 存 
中 取出 CCW 并 加 以 执行 。CSWR 是 通道 状态 字 寄 存 器 ,记录 了 通道 程序 执行 后 本 通道 和 
相应 设备 的 各 种 状态 信息 ,这 些 信息 称 为 通道 状态 字 (CSW)。CSW 通常 放 在 主 存 的 固定 
单元 中 ,此 专用 单元 的 内 容 在 执行 下 一 个 I/O 指令 或 中 断 之 前 是 有 效 的 ,可 供 CPU 了 解 通 
道 \ 设 备 状态 和 操作 结束 的 原因 。 


9.5.3 通道 程序 

1. 通道 指令 

通道 指令 也 就 是 通道 命令 字 (CCW) , 它 用 来 编制 通道 程序 ,并 由 管理 程序 将 它 存放 在 
主 存 的 任何 地 方 。 为 了 使 通道 能 够 快速 地 找到 通道 程序 ,用 通道 地 址 字 (CAW) 指 出 通道 程 
序 的 起 始 地 址 。 在 主 CPU 执行 “启动 I/O? 指 令 启动 指定 通道 后 ,通道 将 执行 通道 程序 来 实 


现 具 体 的 IO 操作 ,直到 组 成 通道 程序 的 全 部 CCW 执行 完毕 时 ,这 次 WO 传送 就 算 完 成 
了 。 通 所 指令 格式 人 简单 ,功能 专 一 ,一 般 市 有 很 强 的 面 铝 外 部 设备 的 特征 。 
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图 9-27 通道 逻辑 结构 


通道 指令 的 功能 和 格式 因 计 算 机 不 同 而 异 ,下 面 介 绍 IBM 4300 的 通道 指令 格式 ,其 格 
式 如 图 9-28 所 示 。 


0 78 31 
命令 人 码 主 存 数 据 地 址 
32 30 48 03 


% 


“3233 34 35 6、 


9-28 ” IBM 4300 通道 指令 格式 


这 是 一 个 双 字 长 (64 位 ) 的 指令 , 共 分 5 个 字段 。 

(1) 命令 码 

命令 码 字 段 相 当 于 机 器 指令 的 操作 码 , 巾 它 决定 通道 和 设备 执行 什么 操作 。 

(2) 主 存 数据 地 址 

通道 指令 中 的 8 一 31 位 ( 共 24 位) 给 出 本 次 I/O 传送 操作 ( 读 、 写 、 反 读 ) 时 主 存 缓冲 区 
的 首 地 址 ,在 数据 传送 过 程 中 ,每 传送 一 个 字 ( 或 字 节 ) ,数据 地 址 修改 一 次 (加 1 或 减 1)。 

(3) 传送 字 节 计数 

通道 指令 中 的 48 一 63 位 ( 共 16 位 ) ,用 来 表示 通道 执行 IO 操作 时 所 传送 的 数据 块 长 
度 , 通 稼 以 字 节 为 单位 。 其 值 可 以 是 传送 的 字 节 数 ,每 传送 一 次 计数 值 减 1; 也 可 以 是 传送 
字 节 数 的 补 数 ,每 传送 一 次 计数 值 加 1, 当 计数 值 为 全 0 时 ,表示 数据 块 传送 完毕 。 

(4) 标志 码 

通道 指令 中 的 32 一 36 位 ( 共 5 位) ,用 来 定义 通道 程序 的 链接 方式 或 通道 命令 的 操作 特 
征 ,统称 为 特征 位 ,各 位 的 含义 如 下 。 

OO 数据 链 特征 : 用 CD 表示 。CD=1, 表 示 接 下 去 的 一 条 通道 指令 也 是 数据 传送 命令 。 
执行 完 本 条 通道 指令 后 不 必 断 开 与 通道 的 逻辑 联系 ,接着 取出 下 一 条 通道 指令 来 执行 即 可 。 
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第 二 条 通道 指令 的 命令 码 和 第 一 条 的 命令 码 相同 。 

GO 命令 链 特 征 : 用 CC 表示 。CC=1, 表 示 本 条 通道 指令 执行 完毕 ,接着 有 不 同 操作 命 
令 的 通道 指令 要 执行 。 执 行 完 本 条 通道 指令 后 要 断 开 与 通道 的 逻辑 联系 ,接着 取 下 一 条 通 
道 指令 。 前 后 两 条 通道 指令 的 命令 码 是 不 相同 的 。 

由 此 可 见 ,只 要 通道 指令 中 的 CD 或 CC 位 为 1, 就 表示 通道 程序 还 没有 结束 ; 当 CD 和 
CC 位 全 为 0 时 ,表示 本 条 通道 指令 是 通道 程序 的 最 后 一 条 指令 ,通道 程序 将 结束 。 

@) 封锁 错误 长 度 特征 : 用 SLI 表示 。 所 谓 长 度 错 , 是 指 当 通道 指令 中 所 给 定 的 传送 字 
节 个 数 与 外 部 设备 请 求 传送 的 字 节 个 数 不 相 等 时 ,通道 指令 执行 完毕 将 产生 长 度 错误 标志 ， 
并 向 CPU 发 中 断 请 求 。 若 SLI=1, 即 使 产生 了 长 度 错 误 标 志 , 也 不 发 送 错误 信号 ,不 产生 
中 断 请 求 ,继续 执行 通道 指令 。 

@ 封锁 写 入 主 存 特征 : 用 SKIP 表示 。SKIP=1 时 ,禁止 将 外 部 设备 读 出 的 数据 写 人 
主 存 。 本 特征 位 若 与 数据 链 特征 位 连用 , 则 可 从 外 部 设备 的 一 批 连 续 数 据 中 任 选 一 部 分 写 
入 主 存 。 

@ 程序 控制 中 断 特征 : 用 PCI 表 示 。PCI=1, 表 示 执 行 本 通道 指令 时 人 允许 产生 一 个 中 
断 条 件 。 


2. 通道 程序 举例 


通道 程序 由 一 条 或 几 条 CCW 组 成 ,在 进行 通道 程序 设计 时 ,要 特别 注意 命令 码 和 标志 
码 的 应 用 。 例 如 ,在 对 磁盘 机 进行 读 写 操作 前 ,要 使 用 控制 命令 查找 磁盘 地 址 ,这 个 地 址 ( 含 
柱 面 号 、 盘 面 号 、 悄 区 号 等 ) 被 包含 在 控制 命令 的 数据 地 址 字段 中 。 根 据 此 命令 使 磁盘 机 进 
es 当 找 到 指定 的 磁盘 数据 区 时 ,通道 才 开 始 执行 真正 的 对 磁盘 机 进行 谈 写 操作 的 
通道 程序 。 下 面 通过 两 个 例子 看 通道 程序 。 
例 9-1 磁盘 写 入 操作 。 
把 主 存 中 3 个 长 度 分 别 为 128 个 字 节 、96 个 字 节 和 256 个 字 节 的 数据 块 写 人 到 磁盘 机 
的 指定 地 址 中 。 这 3 i 台地 址 分 别 为 002000H、002100H、002200H。 同 
时 ,假设 磁盘 数据 区 地 址 已 通过 前 面 的 通道 程序 找到 了 ,因此 完成 磁盘 与 人 操作 的 通关 程序 
如 表 9-6 所 示 。 


表 9-6 磁盘 机 写 入 操作 通道 程序 举例 


通道 指令 主 存 地 址 (十 六 进 制 | ”标志 码 ( 二 进 制 ) 字 节 计 数 (十 进 制 ) 


CCWi 磁盘 写 002000 10000 128 
CCW， 无 用 002100 10000 96 
CCW; 无 用 002200 00000 256 


例 9-2 ”磁带 读 出 操作 。 
从 磁带 机 读 出 一 个 数据 块 ,总 长 度 为 256 个 字 节 ,分 别 放 到 主 存 的 两 个 地 方 , 其 中 第 一 
个 位 置 的 起 始 地 址 为 005000H ,存放 数据 块 开 始 的 120 个 字 节 ;第 二 个 位 置 的 起 始 地 址 为 
006000H ,存放 数据 块 的 最 后 80 个 字 节 ,数据 块 中 间 部 分 的 i 节 不 送 入 主 存 中 ,其 通 
道 程序 如 表 9-7 所 示 。 
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表 9-7 磁带 机 读 出 操作 通道 程序 举例 


通道 指令 主 存 地 址 (十 六 进 制 ) 标志 码 (二 进 制 ) 字 节 计数 (十 进 制 ) 
CCW 1 005000 120 
CCW, 无 用 56 
CCW; 006000 80 


9.5.4 通道 工作 过 程 


通道 完成 一 次 数据 传输 的 主要 过 程 分 为 如 下 3 步 : 

Q 在 用 户 程序 中 使 用 访 管 指令 进入 管理 程序 ,由 CPU 通过 管理 程序 组 织 一 个 通道 程 
序 ,并 启动 通道 。 

G@ 通道 执行 CPU 为 它 组 织 的 通道 程序 ,完成 指定 的 数据 输入 输出 工作 。 

@ 通道 程序 结束 后 向 CPU 发 中 断 请 求 。CPU 响应 这 个 中 断 请 求 后 ,第 二 次 调用 管理 
程序 对 中 断 请 求 进 行 处 理 。 

这 样 , 每 完成 一 次 输入 输出 工作 ,CPU 只 需要 两 次 调用 管理 程序 ,大 大 减少 了 对 用 户 程 
序 的 打扰 。CPU 执行 用 户 程 序 和 管理 程序 ,通道 执行 通道 程序 的 时 间 关 系 如 图 9-29 所 示 。 


请 求 输入 输出 响应 TO 
访 管 指令 中 断 请 求 


CPU 运行 用 户 程序 | | 一 一 一 


| 
CPU 运行 IO 管理 程序 
运行 IO 管理 程序 所 制 通道 程序 
启动 IO 通道 
通道 运行 存放 在 主 存 中 
的 通道 程序 组 织 LO 操作 


问 CPU 发 中 断 请 求 
图 9-29 用 户 程序 ,管理 程序 和 通道 程序 的 执行 时 间 关 系 


习 题 


9-1 什么 是 计算 机 的 输入 输出 系统 ? 输入 输出 设备 有 哪些 编 址 方式 ? 有 什么 特点 ? 

9-2 什么 是 1/O 接口 ? IO 接口 有 哪些 特点 和 功能 ? 接口 有 哪些 类 型 ? 

9-3 并行 接 口 和 串 行 接口 实质 上 的 区 别 是 什么 ? 其 界面 如 何 划分 ? 各 有 什么 特点 ? 

9-4 ”程序 查询 方式 \ 程 序 中 断 方式 .DMA 方式 各 自 适用 什么 范围 ? 下 面 这 些 结论 正确 吗 ?” 为 什么 ? 

(1) 程序 中 断 方式 能 提高 CPU 利用 率 , 所 以 在 设置 了 中 断 方式 后 就 没有 再 应 用 程序 查询 方式 的 必 
要 了 。 

(2) DMA 方式 能 处 理 高 速 外 部 设备 与 主 存 间 的 数据 传送 ,高 速 工作 性 能 往往 能 覆盖 低速 工作 要 求 ， 
所 以 DMA 方式 可 以 完全 取代 程序 中 断 方式 。 

9-5 ”什么 是 程序 查询 IO 传送 方式 ? 试 举例 说 明 其 工作 原理 , 它 有 哪些 优 缺 点 ? 

9-6 9-5 是 以 程序 查询 方式 实现 与 多 台 设 备 进行 数据 交换 的 流程 图 , 试 分 析 这 种 处 理 方式 存在 的 


输入 输出 系统 


问题 以 及 改进 措施 。 

9-7 ”如 果 采 用 程序 查询 方式 从 磁盘 上 输入 一 组 数据 , 设 主机 执行 指令 的 平均 速度 为 100 万 条 指令 每 
秒 ,试问 从 磁盘 上 读 出 相 邻 两 个 数据 的 最 短 允 许 时 间 间 隔 是 多 少 ? 若 改 为 中 断 式 输入 ,这 个 间隔 是 更 短 些 
还 是 更 长 些 ? 由 此 可 得 出 什么 结论 ? 

9-8 在 程序 查询 方式 的 输入 输出 系统 中 ,假设 不 考虑 处 理 时 间 ,每 一 个 查询 操作 需要 100 个 时 钟 周 
期 ,CPU 的 时 钟 频率 为 50MHz。 现 有 鼠标 和 硬盘 两 个 设备 ,而 且 CPU 必须 每 秒 对 鼠标 进行 30 次 查询 , 硬 
盘 以 32 位 字 长 为 单位 传输 数据 , 即 每 32 位 被 CPU 查询 一 次 ,传输 率 为 2MB/s。 求 CPU 对 这 两 个 设备 查 
询 所 花费 的 时 间 比 率 ,由 此 可 得 出 什么 结论 ? 

9-9 什么 是 中 断 ? 外 部 设备 如 何 才 能 产生 中 断 ? 

9-10 ”中断 为 什么 要 判 优 ?” 有 哪些 具体 的 判 优 方法 ? 各 有 什么 优 缺 点 ? 

9-11 CPU 响应 中 断 应 具备 哪些 条 件 ? 

9-12 什么 叫 中 断 隐 指令 ? 中 断 隐 指令 有 哪些 功能 ? 中断 隐 指令 如 何 实现 ? 

9-13 什么 是 中 断 向 量 ? 中 断 向 量 如 何 形成 ? 向 量 中 断 和 非 向 量 中 断 有 何 差 异 ? 

9-14 ”在 程序 中 断 处 理 中 ,要 做 到 现行 程序 向 中 断 服务 程序 过 渡 和 中 断 服务 程序 执行 完毕 返回 现行 
程序 ,必须 进行 哪些 关键 性 操作 ? 一 般 采 用 什么 方法 实现 这 些 操作 ? 

9-15 ”假定 某 计 算 机 的 中 断 处 理 方式 是 将 断 点 存 和 人 00000Q 单元 ,并 从 77777Q 单元 取出 指令 ( 即 中 断 
服务 程序 的 第 一 条 指令 ) 执 行 。 试 排出 完成 此 功能 的 中 断 周 期 微 操作 序列 ,并 判断 出 中 断 服务 程序 的 第 一 
条 指令 是 何 指令 (假定 主 存 容 量 为 25 个 单元 )? 

9-16 ”假设 有 设备 1 和 设备 2 两 个 设备 ,其 优先 级 为 设备 1 二 设备 2, 若 它们 同时 提出 中 断 请 求 , 试 说 
明 中 断 处 理 过 程 , 画 出 其 中 断 处 理 过 程 示意 图 ,并 标 出 断 点 。 

9-17 设 某 计算 机 有 4 个 中 断 源 ,优先 顺序 按 1 一 2 一 3 一 4 降序 排列 , 若 1.2、3、4 中 断 源 的 服务 程序 中 
对 应 的 屏蔽 字 分 别 为 1110.0100.0110、1111, 试 写 出 这 4 个 中 断 源 的 中 断 处 理 次 序 ( 按 降序 排列 ) 。 若 4 个 
中 断 源 同时 有 中 断 请 求 , 画 出 CPU 执行 程序 的 轨迹 。 

9-18 现 有 A、B、C、D 4 个 中 断 源 , 其 优先 级 由 高 向 低 按 A 一 B 一 C 一 D 顺序 排列 。 帮 中断 服务 程序 的 
执行 时 间 为 20ps ,根据 图 9-30 所 示 时 间 轴 给 出 的 中 断 源 请 求 中 断 的 时 刻 , 画 出 CPU 执行 程序 的 轨迹 。 


D 服务 
C 服务 
B 服务 
A 服 务 


0 10 20 30 40 30 60 70 80 90 100 110 120 130140 LNsS) 


B 与 C D B A 
请 求 请 求 请 求 请 求 


图 9-30 ”中断 请 求 时 间 轴 


9-19 ” 设 某 计算 机 有 5 级 中 断 : Lo、Li、Lz、Ls、L ,其 中 断 响应 优先 次 序 为 : Lo 最 高 ,Li 次 之 ,…… ;4 
最 低 。 现 在 要 求 将 中 断 处 理 次 序 改 为 L 习 L; 习 Lo 习 L, 阅 L; ,试问 : 

(1) 各 级 中 断 服务 程序 中 的 各 中 断 屏 项 码 应 如 何 设置 ( 设 每 级 对 应 一 位 , 当 该 位 为 “0”, 表 示 中 断 允许 ; 
当 该 位 为 "1” ,表示 中 断 屏蔽 )? 

(2) 若 这 5 级 同时 都 发 出 中 断 请 求 , 试 画 出 进入 各 级 中 断 处 理 过 程 示 意图 。 

9-20 ”实现 多 重 中 断 应 具备 何 种 条 件 ? 如 有 A、B、C、D 4 级 中 断 ,A 的 优先 级 最 高 ,B 次 之 ,C 再 次 之 ， 
D 最 低 。 如 果 在 程序 执行 过 程 中 ,C 和 DD 同时 申请 中 断 , 该 先 响 应 哪 级 中 断 ? 如 果 正 在 处 理 该 中 断 时 ,A 


四 攻 三。 
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和 B 又 同时 有 中 断 请 求 , 试 画 出 该 多 级 中 断 处 理 的 流程 来 。 

9-21 ”CPU 响应 DMA 请 求 和 响应 中 断 请 求 有 什么 区 别 ? 为 什么 通常 使 DMA 请 求 的 优先 级 高 于 中 
断 请 求 ? 

9-22 ”什么 是 DMA 传送 方式 ? 试 比较 常用 的 3 种 DMA 传送 方法 的 优 缺 点 ? 

9-23 ”实现 DMA 传送 需要 哪些 硬件 支持 ? 

9-24 简 述 DMA 传送 的 工作 过 程 。 

9-25 在 主 存 接 收 从 磁盘 送 来 的 一 批 信息 时 : 

(1) 假定 主 存 的 周期 为 lws, 若 采用 程序 查询 方式 传送 , 试 估算 在 磁盘 上 相 邻 两 数据 字 间 必须 具有 的 
最 短 允 许 时 间 间 隔 是 多 少 ? 

(2) 若 改 为 中 断 方式 传送 ,这 个 时 间 又 会 怎样 ? 是 否 还 有 更 好 的 传送 方式 ? 

(3) 在 采用 更 好 的 传送 方式 下 ,假设 磁盘 上 两 数据 字 间 的 间隔 为 lys, 主 存 又 要 被 CPU 占有 一 半 周 期 
时 间 , 试 计算 这 种 情况 下 主 存 周期 最 少 应 是 多 少 ， 

9-26 ”磁盘 机 采用 DMA 方式 与 主机 通信 ,者 主 存 周期 为 1ps, 能 否 满 足 传输 速率 为 1MB/s 的 磁盘 机 
的 要 求 ? 此 时 CPU 处 于 什么 状态 ? 若 要 求 主 存 有 一 半 时 间 人 允许 CPU 访问 ,该 如 何 处 理 ? 

9-27 ”假定 一 个 字 长 为 32 位 的 CPU 的 主 频 为 500MHz, 硬 盘 的 传输 速率 为 4MB/s。 

(1) 采用 中 断 方式 进行 数据 传送 ,每 次 中 断 传输 4 字 块 数据 。 每 次 中 断 的 开销 (包括 中 断 响应 和 中 断 
处 理 的 时 间 ) 是 500 个 时 钟 周 期 , 问 CPU 用 于 磁盘 数据 传送 的 时 间 占 整个 CPU 时 间 的 百分比 是 多 少 ? 

(2) 采用 DMA 方式 进行 数据 传送 ,每 次 DMA 传输 的 数据 量 为 8KB。 如 果 CPU 在 DMA 预 处 理 时 花 
了 1000 个 时 钟 周期 ,在 DMA 后 处 理 时 花 了 500 个 时 钟 周 期 , 问 CPU 用 于 磁盘 数据 传送 的 时 间 占 整个 
CPU 时 间 的 百分比 为 多 少 ? 

9-28 通道 有 哪些 基本 类 型 ? 各 有 何 特点 ? 

9-29 已 知 一 个 32 位 大 型 计算 机 系统 具有 两 个 选择 通道 和 一 个 字 节 多 路 通道 。 每 个 选择 通道 连接 两 
台 磁 盘 机 和 两 台 磁 带 机 , 字 节 多 路 通道 连接 两 台 打 印 机 \ 两 台 卡 片 输 入 机 和 10 台 CRT 显示 终端 。 假 设 这 
些 设备 的 传输 速率 分 别 为 : 


磁盘 机 800KB/s 
磁带 机 200KB/s 
打印 机 6. 6KB/s 


卡片 输入 机 1. 2KB/s 

CRT 显示 终端 ”1KB/s 

求 该 计算 机 系统 的 最 大 1/O 传输 速率 。 

9-30” 某 计算 机 I/O 系统 中 , 接 有 一 个 字 节 多 路 通道 和 一 个 选择 通道 。 字 节 多 路 通道 包括 3 个 子 通 
道 。 其 中 ,0 号 子 通道 上 接 有 两 台 打 印 机 (传输 率 为 5KB/s) ;1 号 子 通道 上 接 有 3 台 卡 片 输入 机 (传输 率 为 
1. 5KB/s);2 号 子 通道 上 接 8 台 显 示 器 (传输 率 为 IKB/s)。 选 择 通道 上 接 两 台 磁 盘 机 (传输 率 为 800KB/s) ; 
5 台 磁 带 机 (传输 率 为 250KB/s) , 求 IO 系统 的 实际 最 大 流量 。 若 I/O 系统 的 极限 容量 为 822KB/s, 问 能 
否 满足 所 连接 设备 流量 的 要 求 ? 

9-31 试 概括 通道 控制 方式 和 DMA 方式 的 异同 点 。 

9-32 ”什么 是 通道 指令 ? 通道 指令 的 结构 如 何 ? 它 与 CPU 指令 有 何 区 别 ? 它们 的 执行 过 程 相同 吗 ? 

9-33” 简 述 通 道 操作 的 基本 过 程 。 

9-34 ”在 通道 控制 方式 下 ,1/O 操作 由 通道 控制 ,以 达到 CPU 和 I/O 设 备 的 并 行 操 作 , 试 问 : 

(1) 当 通 道 正 在 进行 /O 操作 时 ,CPU 能 否 响 应 其 他 中 断 请 求 ? 

(2) 关 CPU 能 响应 其 他 中 断 请 求 ,是 否 会 影响 正在 进行 的 IO 操作 ? 
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